- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
WPF 文档和教程指出 WPF 与分辨率无关,据我所知,它会在不同分辨率(1600x1200 -> native 和 1024x768)和/或 DPI 设置下显示相同大小的窗口。但是,当我尝试示例应用程序时。不同分辨率的尺寸是不同的。在网上我找到了http://www.wpflearningexperience.com/?p=41 ,它使用“ native 分辨率”以便在不同的计算机上看到相同的窗口大小,但是我无法理解基本概念。
为什么 LCD 的原始分辨率至关重要,而分辨率独立性是一个术语而不是 DPI 独立性?可能我不太了解/使用术语,但我需要澄清才能理解这个问题。
最佳答案
我不想回答我自己的问题,但我想我明白了。很抱歉这个过早的问题,但过了一会儿我注意到了这个问题。
据我了解,WPF 使用系统 DPI(您通过 Windows 桌面设置更改来设置)作为比例因子。例如,在上面的教程中,其中一台计算机的原始分辨率为 1600x1200 和 96 DPI(教程中实际为 94)。一切都很好,因为系统 DPI (96) 非常接近真实 DPI (94),WPF 可以使用此信息来缩放窗口。
如您所知,设备独立单位是 1/96 英寸,实际像素大小(屏幕上的物理像素)以上的数字乘以 ((1/96) * 96) 等于 1。因此,如果你有一个 300 DIU 的窗口,那么你会在屏幕上看到 ( 300/96 ) 英寸。
但是,当您在不更改系统 DPI 的情况下更改分辨率时,就会出现让我困惑的问题。比方说,您将屏幕分辨率设置为 1024x768 而没有更改系统 DPI(仍然是 96)并再次运行该应用程序,您会看到一个更大的窗口。这是错误的系统 DPI 和自然错误的 WPF 比例因子的结果。 WPF 对您的真实 DPI 了解不多,它只使用您提供给它的信息,即系统 DPI。让我们用这个新设置重新计算我们的窗口大小。首先我们需要比例因子 ( (1/96) * 96 ) 等于 1。我们可以说屏幕上的 1 个逻辑像素也是 1 个物理像素。但是,我们更改了分辨率,300 像素与以前的分辨率不一样。以前我们在对角线上有 1600 像素,长度也是 17 英寸。但是,我们现在有 17 英寸的 1024 像素。 300 像素在我们的新分辨率 (1024x768) 中几乎是 5 英寸,但在以前的分辨率 (1600x1200) 中只有 3.18 英寸。因此,由于错误的 DPI 值,WPF 无法独立于分辨率,并使用新的分辨率绘制更大的窗口。
那么,我是如何解决这个问题的(用我的话来说,我并不声称这是一个绝对的解决方案)!当我更改分辨率时,我也更改了适用于此新分辨率的 DPI 值。例如,对于我自己的显示器,对角线尺寸为 17 英寸,分辨率为 1024x768,我使用公式(1024 像素/17 英寸),发现我的新真实 DPI 几乎是 60 DPI。我将系统 DPI 设置为 60(当然是通过桌面设置)并且它有效。由于计算过程中的舍入误差,并不完美,但实际上值可以被认为是相等的。
WPF 使用系统 DPI 以独立于分辨率,您需要设置实际 DPI(当前分辨率的实际 DPI 值)。您需要设置 DPI 以帮助 WPF 无分辨率。最后(我认为非常关键)你还做了一件事,至少在 Windows XP 上,你需要重新启动才能使用新值启用 DPI 设置。如果您不这样做(就像我所做的那样),WPF 仍然会导致计算错误并以不同的大小绘制。
这些是我的理解和我做的测试的结果,但我不能说它们是绝对的。我只想与可能发现此信息有用的人分享。如果您发现任何错误或认为需要改进,请评论/编辑我的帖子。
关于Wpf Resolution Independence 和 Native Resolution,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24939098/
在这种情况下,我们在应用程序中同时使用react-native-gesture-handler Touchable和react-native Touchable。 (通过Touchables,我的意思
我有一个 MainFooter包含页脚和迷你播放器的组件,单击时动画显示为全 View 。我有一个问题,每当我们点击一个页脚选项卡时,播放器最大化然后卡在那里,没有响应。 此外,播放器内部的向下箭
我在 native react 之上使用 native 基础组件,我想知道如何在 UI 中使卡片呈圆形而不是矩形。有圆形的 Prop 吗? 最佳答案 好吧,实际上没有人能回答这个问题,但幸运的是我在
我在 native react 之上使用 native 基础组件,我想知道如何在 UI 中使卡片呈圆形而不是矩形。有圆形的 Prop 吗? 最佳答案 好吧,实际上没有人能回答这个问题,但幸运的是我在
我是 react-native 的新手,所以我认为“HTML”而不是“native”可能有点太多了,所以我的问题看起来很愚蠢。 我使用 react-native-router-flux 进行路由,并使
当我使用这个例子在我的应用程序上实现 Image-slider 时,我遇到了这个错误。 import React,{Component} from 'react' import {View,T
我正在为我们的产品使用“Native Base”组件,并且效果很好, 但我有一点被卡住了,它是关于将 Items 放入 Nativebase Picker 的问题。我的代码是这样的 渲染方法代码 -
正如文档中所建议的,我将一些长的数据获取代码移动到 native 模块中以释放 JS 线程,但我观察到这仍然阻塞了 UI。为什么会这样,我能做些什么来避免这种情况? 从 JS 调用 native 模块
我正在使用一个名为 react-native-svg 的框架在 React Native View 中绘制 SVG 元素。 我的目标是,当我点击 View 时(我在全局 View 上使用 PanRes
在 IOS 中发现错误 Native Module cannot be null 我不使用 react-native-push-notification 最佳答案 这通常发生在您未能将第三个库链接到您
当应用程序关闭时,我可以获得由 Linking.getInitialURL() 点击的深层链接网址。 .当应用程序处于后台状态时,则不会安装任何内容。所以,我什至无法通过 Linking.addEve
1) 说原生库是什么意思?什么样的图书馆?那些将用作 gradle 依赖项? 2)如何链接这些?我在使用 link 或 rnpm 时遇到了麻烦。 最佳答案 链接 native 库意味着您要将已经实现的
我需要帮助来构建我的 react 原生项目。我尝试过react-native run-android,但出现以下错误: react-native : The term 'react-native' i
我需要帮助来构建我的 react 原生项目。我尝试过react-native run-android,但出现以下错误: react-native : The term 'react-native' i
我是 React-Native 的新手,到目前为止我很喜欢它。我正在尝试创建一个屏幕(用于跨平台应用程序),右上角有一个菜单图标,单击时,我想打开一个菜单,希望使用 react-native-menu
RN doco 和其他示例展示了如何从 native iOS View Controller 启动 React-Native View ,但反之则不然。谁能解释一下我该怎么做? 最佳答案 我能够弄清楚
对于 react-native - WebStorm 用户: 我正在使用 Jet Brains IDE WebStorm 开始一个带有 React Native 的项目。 在项目 => node_mo
在升级过去的 react-native 0.60 之后......我被警告我应该取消链接所有手动链接的第 3 方库(因为 RN 现在通过自动链接处理它)。 但是,当我运行 react-native u
你可以使用像 https://github.com/tolu360/react-native-google-places 这样的库吗?在世博项目中?我假设任何 npm 库都可以添加,但是像这个 goo
我主要喜欢 React Native。自 0.22 以来一直在使用它。目前为 0.35。 但是为什么链接原生库就像抽奖一样呢?我很少在第一次拍摄时让它发挥作用,而破裂的东西通常是完全不同的东西。 每个
我是一名优秀的程序员,十分优秀!