【Win10】一些零碎不好归档的小总结(原谅我这个该死的标题吧)

一、同步方式获取设备的屏幕分辨率

public static class ScreenResolution
{
    /// <summary>
    /// 获取屏幕高度。
    /// </summary>
    public static int Height
    {
        get
        {
            var rect = PointerDevice.GetPointerDevices().Last().ScreenRect;
            var scale = DisplayInformation.GetForCurrentView().RawPixelsPerViewPixel;
            return (int)(rect.Height * scale);
        }
    }

    /// <summary>
    /// 获取屏幕宽度。
    /// </summary>
    public static int Width
    {
        get
        {
            var rect = PointerDevice.GetPointerDevices().Last().ScreenRect;
            var scale = DisplayInformation.GetForCurrentView().RawPixelsPerViewPixel;
            return (int)(rect.Width * scale);
        }
    }
}

最初思路来源:http://bbs.wfun.com/thread-860192-1-1.html

测试结果:

Desktop(device Win10 10240)
Correct Value:1920x1080
Test Result:1920x1080

Mobile(emulator W10M 10240 WXGA 4.5 inch)
Correct Value:768x1280
Test Result:768x1280

Mobile(emulator W10M 10240 WVGA 4 inch)
Correct Value:480x800
Test Result:480x854

只有最后一个是不相等的,个人认为是因为虚拟导航栏的原因,因此我觉得该代码理论上是没有问题的,可以投入生产环境。

当然如果不放心的话也可以使用 Win32 API 来获取屏幕分辨率。(已验证此 API 不能在商店应用包中使用,谢谢 @flashcancer 指出)

[DllImport("user32.dll")]
public static extern int GetSystemMetrics(SystemMetric smIndex);
int x = GetSystemMetrics(SystemMetric.SM_CXSCREEN);
int y = GetSystemMetrics(SystemMetric.SM_CYSCREEN);

SystemMetric 是一个枚举类型,定义可以参见:http://pinvoke.net/default.aspx/Enums.SystemMetric

获取出来的结果跟上面 Test Result 是一样的,并且该 API 在 desktop 和 mobile 都可以用。(然而商店不能用,所以然并卵)

商店中允许使用的 Win32 API 一览:https://msdn.microsoft.com/zh-cn/library/windows/apps/jj662956(v=vs.105).aspx(该链接是 WP8 的,但 Win10 应该也差不多)

二、运行时访问 Package.appxmanifest 文件

有些数据是写在 Package.appxmanifest 文件里的,例如磁贴用的图片、启动屏幕用的图片,运行时获取这些信息就只能访问 Package.appxmanifest 文件了。

string manifestPath = Path.Combine(Package.Current.InstalledLocation.Path, "AppxManifest.xml");
XDocument document = XDocument.Load(manifestPath);

编译后,解包我们得知是会变成 AppxManifest.xml 文件,接下来用 XDocument 或者 XmlDocument 解释就可以了。

manifest 的 schema 文档地址:https://msdn.microsoft.com/zh-cn/library/windows/apps/dn934760.aspx

三、获取 GB2312 Encoding

以前 WP8.1 没记错是得到 codeplex 上找这个 Encoding 的,现在不用了。

// 这两句执行一次就可以了,当然重复执行也没坏的。
EncodingProvider provider = CodePagesEncodingProvider.Instance;
Encoding.RegisterProvider(provider);

Encoding gb2312 = Encoding.GetEncoding("gb2312");

// 抛出 ArgumentException
// Encoding doge = Encoding.GetEncoding("doge");

前两句可以放在 App.cs(当然某些人手贱将入口点改成别的也没大问题)里。执行一次就已经可以了。接下来就可以获取 Encoding 了,当然前提是你机子上有这个 Encoding,没有的话就像上面 doge 那样抛出一个 ArgumentException。

四、获取主题色(AccentColor)

public static Color AccentColor
{
    get
    {
        return new UISettings().GetColorValue(UIColorType.Accent);
    }
}

UIColorType 是一个枚举类型,里面还有 Background 的颜色之类的。

当然继续沿用 WP8.1 的方法也可,通过 Resource 来获取,只不过 Win10 里的 ResourceKey 变了。

2015/9/23 更新:

上面该方式仅能在 Desktop 下使用,Mobile 会抛异常。

public static Color AccentColor
{
    get
    {
        return (Color)Application.Current.Resources["SystemAccentColor"];
    }
}

所以还是用回 Resource 来获取吧。。。

五、App.cs 里的 Launched 和 Actived 有啥区别

一图流不解释。

应用生命周期Ex

之前周末休息整理的,不整理不知道,原来这么乱。话说好久没用 Paint.Net 有点不习惯。

此图乃个人整理,请勿当真,如有错漏,请在评论指出。


最后希望工作的面试能过,顺利拿到 offer,然后早点交接完辞掉现在这份好好休息几天(最近感觉有点累)。

posted @ 2015-09-17 23:04  h82258652  阅读(959)  评论(7编辑  收藏  举报