判断用户点击是否在指定区域内

栏目: JavaScript · 发布时间: 6年前

内容简介:首先如果地图没有倾斜判断方式应该是x>左上角(a)的x坐标,小于右上角(b)的x坐标,y>右下角(c)的y坐标,小于右上角(b)的y坐标.这里的坐标系为屏幕坐标系,X轴向右为正,Y轴向下为正。获取到的区域远远超过了 实际可点击区域
近日在地图开发中遇到需要高度显示指定区域的需求,图形画出来了,点击事件却成为一大难题,在canvas中是没有dom点击事件的,只能通过点击区域来判断是否点击了对象.本来如果是正正经经的矩形,判断点击也不是什么难事,偏偏地图就是带着倾斜角度.这样就没办法简单的通过x,y坐标来判断区域问题,需要一个算法.

判断用户点击是否在指定区域内

首先如果地图没有倾斜判断方式应该是x>左上角(a)的x坐标,小于右上角(b)的x坐标,y>右下角(c)的y坐标,小于右上角(b)的y坐标.这里的坐标系为屏幕坐标系,X轴向右为正,Y轴向下为正。

if (x >= a.x && x <= b.x && y >= c.y && y <= b.y){
    //alert(true)
}

获取到的区域远远超过了 实际可点击区域

判断用户点击是否在指定区域内

我们需要把这个区域拆分为四个小区域,判断坐标在不在可点击区域内即可,要用到三角函数中的正切tan

so...

y/x < tan(deg)就是在区域内

能够获取到的鼠标点击的坐标(x,y),矩形四个点坐标(a,b,c,d),地图倾斜角度deg

调用方式应该是:

checkClickArea(x,y,a,b,c,d,deg)

思路有了代码便水到渠成

function checkClickArea(x,y,a,b,c,d,deg) {
    deg = 2 *Math.PI / 360 * deg;
    var pi = Math.tan(deg);
    if(x < a.x || x > c.x || y < b.y || y > d.y){
        return false;
    }else if(x < b.x && y <a.y){
        if((a.y-y)/(x-a.x) > pi){
            return false
        }
        return true
    }else if(x > b.x && y < c.y){
        if((x-b.x) / (y-b.y) > pi){
            return false
        }
        return true
    }else if(x > d.x && y > c.y){
        if((d.y-y)/(x-d.x) < pi){
            return false
        }
        return true
    }else if(x < d.x && y > a.y){
        if((x-a.x)/(y-a.y) < pi){
            return false
        }
        return true
    }else{
        return true
    }
}

其中Math.tan方法是个大坑,需要转换为 2 Math.PI / 360 deg


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

图解物联网

图解物联网

[ 日] NTT DATA集团、河村雅人、大塚纮史、小林佑辅、小山武士、宫崎智也、石黑佑树、小岛康平 / 丁 灵 / 人民邮电出版社 / 2017-4 / 59.00元

本书图例丰富,从设备、传感器及传输协议等构成IoT的技术要素讲起,逐步深入讲解如何灵活运用IoT。内容包括用于实现IoT的架构、传感器的种类及能从传感器获取的信息等,并介绍了传感设备原型设计必需的Arduino等平台及这些平台的选择方法,连接传感器的电路,传感器的数据分析,乃至IoT跟智能手机/可穿戴设备的联动等。此外,本书以作者们开发的IoT系统为例,讲述了硬件设置、无线通信及网络安全等运用Io......一起来看看 《图解物联网》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具