Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Windows and chrome on 4k monitor yields 1.5x resolution #255

Open
ddaeschler opened this issue Jul 23, 2016 · 4 comments
Open

Windows and chrome on 4k monitor yields 1.5x resolution #255

ddaeschler opened this issue Jul 23, 2016 · 4 comments

Comments

@ddaeschler
Copy link

Using a 4k monitor and chrome on windows, retinajs attemptes to load images with @1.5x appended rather than an integer value like @2x.

By quick source inspection, I think this means window.devicePixelRatio is returning 1.5.

In this case, a simple change of:

const environment = hasWindow ? (window.devicePixelRatio || 1) : 1;
to
const environment = hasWindow ? Math.ceil(window.devicePixelRatio || 1) : 1;

Would fix the problem

@ddaeschler
Copy link
Author

For reference, this behavior was seen on a Dell P2715Q 27-Inch 4k monitor

@wallacio
Copy link

wallacio commented Sep 6, 2016

Agreed. I actually noticed this by chance, seeing some rather odd 404s for images which retina.js was looking for because of a non-integer window.devicePixelRatio. I've no idea what device they were caused by, but there's no way I'm going to cater for this kind of request (these are real)...

/i/jwflogo@1.149999976158142x.png
/i/jwflogo@1.0499999523162841x.png
/i/jwflogo@1.25x.png

If we need to cater for rational number devicePixelRatios, these would surely have to be defined as a finite list at initialisation.

(retina.js v2.0.0)

@adojck
Copy link

adojck commented Sep 29, 2016

For me, Chrome on Windows 10 uses Windows scaling ratio. For example I use 1.5 (150%) so browser identifies my resolution as 2560x1440, but I have 4K monitor with resolution 3840x2160. I have tried retina.js 2.1.0 but it did not work at all (seems to be already reported) and with retina.js 2.0.0 I got request from server for @1.5x picture. Seems to be right, but I don't want to have extra image for 1.5 ratio.

Not sure if this is an issue, looks like a feature. But I would prefer having 3 images on server (original, 2x and 3x) and not for (+1.5x).

Maybe someone has a solution how to set ratios to be "integer" instead of "float"?

@kleuter
Copy link

kleuter commented Oct 12, 2016

#261

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants