gpt4 book ai didi

javascript - 检测鼠标悬停并显示 HTML Canvas 上点的工具提示文本

转载 作者:行者123 更新时间:2023-11-28 02:47:09 25 4
gpt4 key购买 nike

我最近创建了一个“ map ”,虽然不是很复杂(正在研究它),但它具有基本功能,并且总体上朝着正确的方向前进。

如果你看它,你可以看到一个微小的红点,在这些微小的红点上,我想将鼠标悬停在它上面并基本上看到文本,但我在获取正确的代码时遇到了一些麻烦。

http://hummingbird2.x10.mx/website%20creation/mainpage.htm

这是到目前为止的所有代码。

 <!DOCTYPE html PUBLIC "-//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">
<head>
<title>Oynx Warrior</title>
<link rel="stylesheet" type="text/css" href="mystyle.css" />

</head>
<body>
<h1>Oynx Warrior</h1>

<canvas id="myCanvas" width="500" height="500" style="border:1px solid #c3c3c3;">
Your browser does not support the canvas element.
</canvas>

<script type="text/javascript">
var c=document.getElementById("myCanvas");
var cxt=c.getContext("2d");
cxt.fillStyle="#red";
cxt.beginPath();
cxt.arc(50,50,1,0,Math.PI*2,true);
cxt.closePath();
cxt.fill();

</script>
</body>
</html>

最佳答案

这里有四个选项:

  1. 跟踪所有点的位置并跟踪 mousemove body 上的事件。当鼠标移到一个点上时,用文本重新绘制 Canvas 。当鼠标移开时,清除 Canvas 并重新绘制没有文本的 Canvas 。您必须编写自己的“命中”检测代码来将鼠标位置与所有点的边界框/半径进行比较。这很难,但并非不可能。

  2. 不要使用一张 Canvas 来显示整个 map ,而是使用 Canvas 来创建自定义点,请调用 toDataURL()在 Canvas 上为其获取字符串,创建一个新的绝对定位 <div>每个点的元素,并设置 .style.backgroundImage = url('+myDotDataURL+'); 。现在您只需设置 title每个 div 上的属性,并让浏览器为您处理鼠标检测和工具提示显示。缺点:您将看到点周围方形区域的工具提示,而不是点本身。

  3. 不要使用 HTML Canvas,而是使用 SVG。在 SVG 中,绘制的“元素”是具有自己的事件和命中检测的实际对象。通过此功能,您可以绘制自定义点,并让浏览器为您完成所有鼠标点击操作。

关于javascript - 检测鼠标悬停并显示 HTML Canvas 上点的工具提示文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4655993/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com