質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
87.20%
CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

解決済

[JS]マウスを追いかける目玉の焦点が合わない

josterjonathan
josterjonathan

総合スコア24

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

1回答

0評価

1クリップ

180閲覧

投稿2022/05/17 05:57

編集2022/05/17 22:24

マウスを追って目を動かす目玉を HTML/CSS で作成しています.
目玉の中央にマウスを置くと目玉は真っ直ぐ前を向き,マウスを任意の方向に動かすと目玉はその方向に向く,というような完成形をイメージしています.
その際,エレメントの座標の処理をどこかで間違えているようで,思った通りの挙動を示しません.
マウスを目で追う挙動ではなく,その右上を見ている状態です.

JavaScript

const ball = document.querySelector('.ball'); // 目玉のエレメント document.onmousemove = () => { let left2center = document.body.clientWidth / 2; // ウィンドウ左端から中央までの長さ let top2center = document.body.clientHeight / 2; // ウィンドウ上端から中央までの長さ let offsetx = left2center - ball.getBoundingClientRect().left + 0; // ここが不適当? let offsety = top2center - ball.getBoundingClientRect().top + 0; // ここが不適当? var x = (event.clientX + offsetx) * 100 / window.innerWidth + "%"; var y = (event.clientY + offsety) * 100 / window.innerHeight + "%"; ball.style.left = x; ball.style.top = y; ball.style.transform = `translate(-${x}, -${y})`; }

コード中 offsetxoffsety で中央からのずれを表しているつもりなのですが,どこか勘違いをしているようで...
ご教示よろしくお願いします.


HTML

<!DOCTYPE html> <html lang="en" dir="ltr"> <head> <link rel="stylesheet" href="style.css"> </head> <body> <div class="eyes"> <div class="eye"> <div class="ball"></div> </div> </div> <script><!-- 同上 --></script> </body> </html>

CSS

body{ margin: 0; padding: 0; } .eyes{ position: absolute; top: 50%; transform: translateY(-50%); width: 100%; text-align: center; } .eye{ width: 10rem; height: 10rem; background: #ddd; display: inline-block; border-radius: 50%; position: relative; overflow: hidden; margin: 2rem; } .ball{ width: 5rem; height: 5rem; background: #000; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); border-radius: 50%; border: 1rem solid #333; }

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

y_waiwai

2022/05/17 08:26

思った通りの挙動を示しません、とはどの様になるんでしょうか
Lhankor_Mhy

2022/05/17 09:53

確認させてください。 画面幅が1000pxで目玉が完全に中央にあり、1rem=16px、clientXが500pxの場合、 left2center = 1000/2 = 500px offsetx = 500 - 452 + 0 = 48px x = (500 + 48) * 100 / 1000 + "%" = "54.8%" という値になりそうですが、これは想定通りですか?

まだ回答がついていません

会員登録して回答してみよう

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
87.20%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。