qq_31944539 2015-10-14 07:02 采纳率: 66.7%
浏览 3364
已采纳

canvas怎么设置鼠标事件?怎么获取里面的点?

function() {

var graph = document.getElementById('canvas');

if (graph.getContext){
var g = graph.getContext('2d');
g.strokeStyle = '#000';
g.beginPath();
for (var i = 0, l = a.length; i < l; i++) {
g.arc((i + 1) * 100,a[i],3,0,Math.PI*2,true);
g.fill();
g.lineTo((i + 1) * 100,a[i]);

}
g.fillStyle="black";
g.stroke();
g.closePath();
图片说明
想做出鼠标滑动到点上时,有一个信息框显示出来,大神们帮我!

  • 写回答

3条回答

  • Go 旅城通票 2015-10-15 06:43
    关注

    用这个吧,忘记计算canvas的位置了

     <style>
        #note{position:absolute;display:none;border:solid 1px #000;background:#fff}
    </style>
    <canvas id="canvas" style="border:solid 1px #000;margin:100px 0 0  100px;" width="1000"></canvas>
    <div id="note"></div>
    <script>
        var a = [10, 20, 30, 40, 50, 20, 30, 40],note=document.getElementById('note');
        var c = document.getElementById('canvas');
        function getLeftRight(o) {
            var p = { x: o.offsetLeft, y: o.offsetTop };
            while (o = o.offsetParent) { p.x += o.offsetLeft; p.y += o.offsetTop; }
            return p;
        }
        function hitCheck(x, y, point, r) {//检查是否移动到点上,直接按照正方形检查了,圆形比较麻烦
            var x1 = point.x, y1 = point.y;
            return x1 + r > x && x1 - r < x && y1 + r > y && y1 - r < y;
        }
        if (c.getContext) {
            var g = c.getContext('2d');
            var points = [];//原点圆心集合
            var r = 3;//半径
            var cP = getLeftRight(c);//获取canvas对象位置
            for (var i = 0, l = a.length; i < l; i++) {
                points[i] = { x: (i + 1) * 100, y: a[i] };
                g.beginPath();
                g.moveTo(i * 100, i - 1 < 0 ? 0 : a[i - 1]);
                g.lineTo((i + 1) * 100, a[i]);
                g.arc((i + 1) * 100, a[i], r, 0, Math.PI * 2, true);
                g.fill();
                g.stroke();
                g.closePath()
            }
            var timer;
            c.addEventListener('mousemove', function (e) {
                clearTimeout(timer);
                var x = e.clientX, y = e.clientY;
                timer = setTimeout(function () {
                    for (var i = 0; i < points.length; i++) 
                        if (hitCheck(x - cP.x, y - cP.y, points[i], r)) {
                            note.style.display = 'block';
                            note.style.left = points[i].x +cP.x+ r + 1 + 'px';
                            note.style.top = points[i].y + cP.y + r + 1 + 'px';
                            note.innerHTML = 'X:' + points[i].x + '  Y:' + points[i].y;
                            return
                        }
    
                    note.style.display = 'none';
                }, 100);
            }, false);
        }
    </script>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决