1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

【JavaScript】Shadow DOMを取得しGoogle Earthの地球儀を自動回転する方法

Last updated at Posted at 2023-01-13

【概要】

Google Earthの地球儀表示部分はShadow DOMで生成されています。
Shadow DOMの要素はgetElementByIdなどを使用して取得することができませんが、開発者ツールから取得できます。
取得したShadow DOMに対して、キーボードの"→"キー押下のイベントを発火させることで地球儀を自動回転します。

【環境】

Google Chrome

【実行手順】

1. Google Earthを起動する

下記リンク先へ遷移します。
Google Earth

Earth を起動ボタンをクリックします。

Google Earth

新しいタブが開き、地球儀が表示されます。

Google Earth

2. 地球儀要素の特定をする

開発者ツールを開き地球儀の要素を選択します。

developer tool

地球儀の要素を選択すると自動的にElementsタブが開き、canvas要素にフォーカスが当たります。

canvas

3. Shadow DOMを取得する

canvas要素のすぐ上にあるshadow-root要素を右クリックし、Store as global variableの項目をクリックします。

Shadow DOM

クリックするとtemp1という変数名でShadow DOMが取得できます。

Shadow DOM

4. 地球儀を自動回転する

コンソールに下記コマンドを入力し、実行します。
実行すると地球儀が自動回転します。

temp1.getElementById('canvas').dispatchEvent(new KeyboardEvent("keydown", { keyCode: 39 }));

※ちなみに原因はわかりませんが、上記コマンドと同じ意味合いの下記コマンドでは自動回転することはできませんでした

temp1.getElementById('canvas').dispatchEvent(new KeyboardEvent("keydown", { key: "ArrowRight" }));

animation

【参考サイト】

Javascriptで疑似的にKeyUpイベントを発火させる方法
JavaScript で矢印キーの押下を検出する

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?