mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-08 20:09:36 +01:00
Ported: Improve performance of screen_get_dpi() in Javascript
Replace a bisect with a single multiplication when calling
screen_get_dpi() in Javascript
Tested the value of
window.matchMedia(`(resolution:${(window.devicePixelRatio*96).toFixed(100)}dpi)`).matches
which is true except for values that cause a lot of rounding errors
(e.g. dpr : 0.3 => resolution: 28.799999999999997dpi)
Even in these cases the value matches the result of the previous
`findDPI()` method.
-jamie-pate
562d7c616d
This commit is contained in:
parent
fefc436645
commit
bcf96a5840
@ -335,27 +335,12 @@ const PandemoniumDisplay = {
|
|||||||
$PandemoniumDisplay__deps: ['$PandemoniumConfig', '$PandemoniumRuntime', '$PandemoniumDisplayCursor', '$PandemoniumEventListeners', '$PandemoniumDisplayScreen', '$PandemoniumDisplayVK'],
|
$PandemoniumDisplay__deps: ['$PandemoniumConfig', '$PandemoniumRuntime', '$PandemoniumDisplayCursor', '$PandemoniumEventListeners', '$PandemoniumDisplayScreen', '$PandemoniumDisplayVK'],
|
||||||
$PandemoniumDisplay: {
|
$PandemoniumDisplay: {
|
||||||
window_icon: '',
|
window_icon: '',
|
||||||
findDPI: function() {
|
getDPI: function() {
|
||||||
function testDPI(dpi) {
|
// devicePixelRatio is given in dppx
|
||||||
return window.matchMedia(`(max-resolution: ${dpi}dpi)`).matches;
|
// https://drafts.csswg.org/css-values/#resolution
|
||||||
}
|
// > due to the 1:96 fixed ratio of CSS *in* to CSS *px*, 1dppx is equivalent to 96dpi.
|
||||||
|
const dpi = Math.round(window.devicePixelRatio * 96);
|
||||||
function bisect(low, high, func) {
|
return dpi >= 96 ? dpi : 96;
|
||||||
const mid = parseInt(((high - low) / 2) + low, 10);
|
|
||||||
if (high - low <= 1) {
|
|
||||||
return func(high) ? high : low;
|
|
||||||
}
|
|
||||||
if (func(mid)) {
|
|
||||||
return bisect(low, mid, func);
|
|
||||||
}
|
|
||||||
return bisect(mid, high, func);
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
const dpi = bisect(0, 800, testDPI);
|
|
||||||
return dpi >= 96 ? dpi : 96;
|
|
||||||
} catch (e) {
|
|
||||||
return 96;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -388,7 +373,7 @@ const PandemoniumDisplay = {
|
|||||||
|
|
||||||
pandemonium_js_display_screen_dpi_get__sig: 'i',
|
pandemonium_js_display_screen_dpi_get__sig: 'i',
|
||||||
pandemonium_js_display_screen_dpi_get: function() {
|
pandemonium_js_display_screen_dpi_get: function() {
|
||||||
return PandemoniumDisplay.findDPI();
|
return PandemoniumDisplay.getDPI();
|
||||||
},
|
},
|
||||||
|
|
||||||
pandemonium_js_display_pixel_ratio_get__sig: 'f',
|
pandemonium_js_display_pixel_ratio_get__sig: 'f',
|
||||||
|
Loading…
Reference in New Issue
Block a user