document.querySelector('img').requestFullScreen()
とかすると画像が全画面表示されるやつ。画面ロード直後にいきなり全画面表示とかはできないようになってるのでclickイベント内とかで行う。
詳しくは以下
画像ギャラリー的なUIでの利用を想定してみる。画像をクリックしたら最大化表示されるやつ。
<style>
img{
width: 300px;
height: 233px;
border: solid 4px #aaa;
border-radius: 16px;
}
img:hover{
border-color: #00aaff;
cursor: pointer;
}
</style>
</head>
<body>
<h1>FullScreen Demo for Chrome/Safari</h1>
<img src="https://lh5.googleusercontent.com/-7cggVHG-i74/U5M05ee0DAI/AAAAAAAAHWA/iM3hb0gONVc/s800/IMG_1727.png"/>
<img src="https://lh4.googleusercontent.com/-E-GSa8wymBs/U5MzX0_5G7I/AAAAAAAAHVM/S2igEXSg8nU/s800/IMG_1778.png"/>
<script>
var images = document.querySelectorAll('img');
Array.prototype.forEach.call(images, function (image, index, nodeList) {
image.addEventListener('click', function(){
if(image.webkitRequestFullScreen) {
image.webkitRequestFullScreen();
}
});
});
data:image/s3,"s3://crabby-images/d7560/d75609cc3786d2feae654d028441863e940b6249" alt="gallery.png"
最大化されない
Firefoxの場合、styleのサイズ指定が無視されでっかく表示されるけど、Chrome/Safariの場合は小さいままになってしまう。
Firefox
data:image/s3,"s3://crabby-images/b3cb4/b3cb4bb4c80306816e0745696a610753a9289a99" alt="firefox_full.png"
Chrome/Safari
data:image/s3,"s3://crabby-images/9219b/9219b977147dae14bcc0cc598f33ce14f485253e" alt="chrome_full.png"
MDNによると以下でFirefoxと同じ挙動になるとのこと。
img:-webkit-full-screen {
width: 100%;
height: 100%;
}
なんか長細くて変w
data:image/s3,"s3://crabby-images/6b495/6b495ca5526aaf22958d0505b23da5a24c54e97b" alt="chrome_full2.png"
FullScreen化された時だけ、サムネイル時のstyleを解除するといい感じに動くみたい。
<style>
.noFullScreen img{
width: 300px;
height: 233px;
border: solid 4px #aaa;
border-radius: 16px;
display: inline-block;
}
.noFullScreen img:hover{
border-color: #00aaff;
cursor: pointer;
}
</style>
<script>
document.addEventListener('webkitfullscreenchange', function(){
var image = document.webkitFullscreenElement;
if(image){
document.body.classList.remove('noFullScreen');
}
else{
document.body.classList.add('noFullScreen');
}
}, false);
</script>
data:image/s3,"s3://crabby-images/e53d8/e53d8096fa438b5e6fad952ddef6a529da56df34" alt="chrome_full3.png"
Chromeの場合のみ最大化解除後、段積みになっちゃう
Chromeの場合のみ以下みたいになってしまう。バグかな。
data:image/s3,"s3://crabby-images/a33b5/a33b525d23c1544fc2c053086ed520fc05b5629f" alt="gallery_chrome.png"
これについてはinline-block
を指定すれば解決するっぽい。
.noFullScreen img{
width: 300px;
height: 233px;
border: solid 4px #aaa;
border-radius: 16px;
display: inline-block; /* 追加 */
}