Is there a way to detect if the device has a Retina display using PHP not JavaScript? I would like to deliver a different image according to the screen.
Asked
Active
Viewed 243 times
-3
-
Post what you have tried? – Apr 18 '18 at 07:01
-
@Bulat why did you mark it as a duplocate? You have added duplicate answer for javascript solution, when the question is actually asked about php solution. – Alexandr Nov 29 '19 at 09:52
1 Answers
1
I tried the same thing with the combination of JS, PHP and Cookies.
Try the below code and check whether it's useful for you.
<?php
if( isset($_COOKIE["device_pixel_ratio"]) ){
$is_retina = ( $_COOKIE["device_pixel_ratio"] >= 2 );
if( $is_retina)
$thumbnail = get_image( $item_photo, 'thumbnail_retina' ) ;
else
$thumbnail = get_image( $item_photo, 'thumbnail' ) ;
}else{
?>
<script language="javascript">
(function(){
if( document.cookie.indexOf('device_pixel_ratio') == -1
&& 'devicePixelRatio' in window
&& window.devicePixelRatio == 2 ){
var date = new Date();
date.setTime( date.getTime() + 3600000 );
document.cookie = 'device_pixel_ratio=' + window.devicePixelRatio + ';' + ' expires=' + date.toUTCString() +'; path=/';
//if cookies are not blocked, reload the page
if(document.cookie.indexOf('device_pixel_ratio') != -1) {
window.location.reload();
}
}
})();
</script>
<?php } ?>
in function.php :
add_action( 'init', 'CJG_retina' );
function CJG_retina(){
global $is_retina;
$is_retina = isset( $_COOKIE["device_pixel_ratio"] ) AND $_COOKIE["device_pixel_ratio"] >= 2;
}
Then after use the following GLOBAL:
global $is_retina; or $GLOBALS['is_retina'];