スクリーンオーバーレイの表示/非表示の切り替え
スクリーンオーバーレイを追加した後で表示と非表示を切り替える方法を確認します。
スクリーンオーバーレイのオブジェクトが表示されているかどうか確認するにはGScreenOverlayクラスで定義されているisHiddenメソッドを使います。
isHidden()
画面オーバーレイが現在非表示の場合に、true を返します。それ以外の場合は、 false を返します。 戻り値: Boolean
現在スクリーンオーバーレイが表示されていればtrueを返し、表示されていなければfalseを返します。
非表示となっているスクリーンオーバーレイを表示するにはGScreenOverlayクラスで定義されているshowメソッドを使います。
show()
画面オーバーレイが現在非表示である場合に、表示します。画面オーバーレイが 現在非表示の場合は、この関数はイベント GScreenOverlay.visibilitychanged をトリガします。
showメソッドを実行すると、スクリーンオーバーレイが非表示の場合に表示します。
表示されているスクリーンオーバーレイを非表示にするにはGScreenOverlayクラスで定義されているhideメソッドを使います。
hide()
画面オーバーレイが現在表示されている場合に、非表示にします。画面オーバー レイが現在表示されている場合は、この関数はイベント GScreenOverlay.visibilitychanged をトリガします。
hideメソッドを実行すると、スクリーンオーバーレイが表示されている場合に非表示にします。
具体的には次のように記述します。
var map = new GMap2(document.getElementById("map"));
map.setCenter(new GLatLng(33.591243,130.412006), 13);
var soverlay = new GScreenOverlay("./sample.png", screenXY, overlayXY, size);
map.addOverlay(soverlay);
if (soverlay.isHidden()){
soverlay.show();
}else{
soverlay.hide();
}
サンプル
では試してみます。
var map;
var soverlay;
function initialize() {
if (GBrowserIsCompatible()) {
map = new GMap2(document.getElementById("map_canvas"));
map.setCenter(new GLatLng(35.93368,140.673409), 12);
var screenXY = new GScreenPoint(290, 290);
var overlayXY = new GScreenPoint(0, 0);
var size = new GScreenSize(100, 100);
soverlay = new GScreenOverlay("./img/sun.png", screenXY, overlayXY, size);
map.addOverlay(soverlay);
}
}
function onoff() {
if (soverlay.isHidden()){
soverlay.show();
document.getElementById("onoffbtn").value = "非表示";
}else{
soverlay.hide();
document.getElementById("onoffbtn").value = "表示";
}
}
<!DOCTYPE html "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:v="urn:schemas-microsoft-com:vml">
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
<title>サンプル:スクリーンオーバーレイの表示/非表示の切り替え</title>
<script src="http://maps.google.com/maps?file=api&v=2&key=(key)&sensor=false"
type="text/javascript" charset="utf-8"></script>
<script src="./js/code4_1.js" type="text/javascript"></script>
</head>
<body onload="initialize()" onunload="GUnload()">
<div id="map_canvas" style="width: 400px; height: 400px"></div>
<form>
<p>
<input type="button" id="onoffbtn" value="非表示" onclick="onoff()" />
</p>
</form>
</body>
</html>
ではブラウザで上記のURLを見てみます。
では地図下の「非表示」ボタンを押して下さい。
スクリーンオーバーレイが非表示になります。
地図下の「表示」ボタンを押せば再度表示されます。
( Written by Tatsuo Ikura )
AjaxTower