Javascriptと正確にはCSSを使って、ウィンドウをスクリプト側から縮小させる方法です。
Firefoxは、IEやChromeにはある「zoom: 1.0;」のようなCSSがなく、独自に「.MozTransform=”scale(0.1)”;」があります。しかしこれ、ちょっとやっかいで縮小するとウィンドウが中央に配置されて、画面のまわりが余白だらけになってしまいます。これをどうにか左寄せしようと思います。
そのまえに問題です
xが0.1のとき
13000
xが0.2のとき
5800
xが0.5のとき
1440Code language: CSS (css)
このxの数式がなんなのか当ててみましょう。
私は・・わかりませんでした・・・orz
これはワイド画面のディスプレイでとあるページで画面の左上寄せに必要だった余白部分のサイズの数値です。
しょうがないので、Firefoxの縮小の挙動を考えてみることにしました。
ウィンドウの横の長さが980だったとしたら、それを0.8倍にしたら、784。
つまり、もともとのウィンドウのサイズ980-784で196だけ小さくなった。
この196というのは余白分。画面は中央に表示されているので、左と右の2つの幅ということになる。
なので、これを2で割ると、その半分の余白のサイズが求められます。
そしてらできた
<span class="synIdentifier">var</span> htmlElm = <span class="synStatement">document</span>.getElementsByTagName(<span class="synConstant">"html"</span>)<span class="synIdentifier">[</span>0<span class="synIdentifier">]</span>;
htmlElm.style.MozTransform=<span class="synConstant">"scale(1)"</span>;
<span class="synIdentifier">var</span> sx = <span class="synStatement">document</span>.body.clientWidth * 1.0;
<span class="synIdentifier">var</span> sy = <span class="synStatement">document</span>.body.clientHeight * 1.0;
<span class="synIdentifier">var</span> a = 0.5;
htmlElm.style.position = <span class="synConstant">"absolute"</span>;
htmlElm.style.left = <span class="synConstant">"-"</span>+((sx-sx*a)/2.0)+<span class="synConstant">"px"</span>;
htmlElm.style.<span class="synStatement">top</span> = <span class="synConstant">"-"</span>+((sy-sy*a)/1.98)+<span class="synConstant">"px"</span>;
htmlElm.style.MozTransform=<span class="synConstant">"scale("</span>+a+<span class="synConstant">")"</span>;
Code language: HTML, XML (xml)
フレームページの場合はこうする。
var sx = document.getElementById("iframe").contentDocument.body.scrollWidth * 1.0;
var sy = document.getElementById("iframe").contentDocument.body.scrollHeight * 1.0;Code language: JavaScript (javascript)