- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我用不同的 OpenLayers-Versions 创建了两个相同的 fiddle :
OpenLayers v3.18.0和 OpenLayers 4.1.1
目标是以高分辨率导出 PNG。我没有包括文件的实际导出。解释here如果有兴趣。
在更新版本之前一切正常(我认为直到 4.x 版本)。
如果您在 Windows 中将 DPI-Setting 设置为 100%,则两个 fiddle 都会执行相同的操作 - 但如果您将 DPI-Setting 更改为 125%,则后者不会更新文本 Some text!它变得非常小并且位于错误的位置。
map 保持不变,直到我点击它(或者我调用 map.updateSize()
)。所以我想,我加 map.updateSize()
在 precompose
结尾- 但无论我在哪里做,导出的图像都是错误的 updateSize()
似乎是异步的,并且在 postcompose 之后发生。
我没有发现关于这个问题的重大变化。我忽略了什么还是一个错误?任何解决方法的建议?
最佳答案
感谢 issue I opened on github我想出了以下解决方案。最有趣的部分是创建第二个 ol.Map
带有所需的pixelRatio
:
saveToFile = function (fileName, opt_ChangeSize, opt_PixelRatio, opt_DelayRenderPromise) {
var newMapComponent,
originalSize = mapComponent.getSize();
opt_ChangeSize = opt_ChangeSize || { width: originalSize[0], height: originalSize[1] };
var div = $(document.createElement("div"));
div.attr('id', 'DIV_SaveToFile_Renderer_' + (new Date()).getTime());
div.css('position', 'absolute');
div.css('top', '0');
div.css('left', '0');
div.css('visibility', 'hidden');
div.css('width', opt_ChangeSize.width + 'px');
div.css('height', opt_ChangeSize.height + 'px');
$('body').append(div);
newMapComponent = new ol.Map({
target: div[0].id,
layers: mapComponent.getLayers(),
pixelRatio: opt_PixelRatio,
view: mapComponent.getView()
});
// opt_DelayRenderPromise in this case returns when loading of some features has completed. It could also be postrender of map or whatever.
$q.when(opt_DelayRenderPromise).then(function () {
$timeout(function () {
var data,
canvas = div.find('canvas')[0];
data = canvas.toDataURL('image/png');
data = data.replace(/^data:image\/(png);base64,/, "");
MyUtilities.SaveBlobFromBase64(data, fileName);
div.remove();
mapComponent.setSize(originalSize);
mapComponent.renderSync();
});
});
mapComponent.setSize([opt_ChangeSize.width, opt_ChangeSize.height]);
mapComponent.renderSync();
};
关于html5-canvas - 开放层 3 : Scaling canvas with text with 125% DPI since v4. x,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44285584/
我 Handlebars 机图片尺寸调整为731*974,但还是有920KB。所以我想将图像分辨率从96dpi更改为72dpi(因为我发现iPhone中的图片是72dpi,看起来不错)。任何人都可以提
我制作了这个非常简单的计算器布局。但是我手机上的 480 DPI 和 420 DPI 是不同的。 420DPI 屏幕右侧有空闲空间,按钮比 480DPI 更细。我使用 dp 作为按钮的测量单位,sp
使用 phantomjs ,有没有办法控制使用 page.render(filename) 光栅化 Web 内容的图像时使用的 DPI 设置?方法? 我找不到任何可以通过 the interface
众所周知,Windows 7 可用的 DPI 缩放比例为 100%、125%、150% 和 200%。这四个DPI百分比的实际DPI值是 Percentage - DPI Values 100%
我试图找到 WinMerge 的替代方案来解决 150% DPI 下的文本模糊问题。虽然我的问题被关闭了(我认为这种心态没有帮助),但我找到了答案所以我分享它。 最佳答案 您可以继续使用 WinMer
我有一些我想打印出来的图像。这些图像可以采用不同的格式,从不同的 DPI 到不同的格式(JPEG、PNG 等) 现在我所做的是将图像加载到我的应用程序中并尝试 将 dpi 转换为 96。但是在这个过程
DPI 和 PPI 有什么区别吗?是这样吗:点 = 像素?最后,C#.net 中的 DpiX 和 DpiY 是什么?我们如何改变它们? 最佳答案 新闻部 代表每英寸点数,在打印时使用。它也被严重滥用于
我有一个可视化代码,例如: for cluster in ready_couples_2.cluster.unique(): sns.set(rc={'figure.figsize':(11.
我正在努力优化我的网络应用程序中的滚动性能,并在最新的 Chrome (v31) 上遇到了有趣的行为,该行为也在 Chrome Canary (v34) 上重现。 在这个简化的示例中,我有一个简单的可
我正在构建一个具有 hdpi 分辨率图形 Assets 的游戏(因此我将文件放在 drawable-hdpi 目录中)。我不希望图像具有相应的 mdpi 分辨率,我将在基于 240-dpi 的像素坐标
我必须重新布局一个非常复杂的 UI,因为我们发现它在高 dpi 系统上基本上不可用。这是因为为了在 Qt Creator 中获得我们想要的布局设计,我们对几乎所有内容都使用了固定大小。 我的问题是,如
我的系统上安装了 Win 8.1 系统。我曾经根据我的 WPF 应用程序 (Win 7) 中的以下内容计算 DPI: Matrix m = PresentationSource.FromVisual(
我有一个使用 Substance LookAndFeel 的 Java 应用程序,Windows 作为目标平台,我想增加我的应用程序的 DPI 设置, 不更改系统设置。 我想这样做是因为我不想强制用户
我有一个非常奇怪的问题......在我的 iPhone 应用程序中,用户可以打开相机胶卷中的图像,在我的示例中 1920 x 1080 像素 (72 dpi) 的壁纸。 现在,想要将图像的宽度调整为例
我遇到一个问题,应用程序(用 Delphi 编写)在所有系统上的默认 96 DPI 设置下表现正常,但在不同系统上的“150% 文本大小”(内部 144 dpi)设置下表现不一致。似乎在某些系统上,我
我看过官方Qt documentation以及 StackOverflow 上关于 Qt 中高 DPI 支持的许多文章和问题。他们都专注于移植旧的应用程序并让它们以尽可能少的更改工作。 但是,如果我要
在matplotlib中,我使用LineCollection绘制国家/地区的颜色,并指定了县/市的边界。当我将图形另存为pdf文件时: fig.savefig('filename.pdf',dpi=3
我想以编程方式确定用户显示器的 DPI,以便以精确的单位数(厘米/英寸)显示网页。我知道这是一个奇怪的要求:它是针对一个可视化研究项目的,它是一种控制。我们目前通过让用户将信用卡放在屏幕上并将可调整大
我使用 matplotlib 创建了一个图形,但我已经意识到绘图轴和绘制的线被缩小了。 阅读本文 earlier discussion thread ,它解释了如何设置图形大小。 fig, ax =
晚安,我正在与一些合作伙伴使用 javaFx 制作一个应用程序;我们的想法是它将在 Windows 和 Linux 中使用。我们进行了一些测试,发现应用程序在两种操作系统中的显示有所不同。 我们正在使
我是一名优秀的程序员,十分优秀!