博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何在页面上实现一个圆形的可点击区域?
阅读量:4129 次
发布时间:2019-05-25

本文共 1256 字,大约阅读时间需要 4 分钟。

方法一:通过map加area

<img>标签中的 usemap 属性将图像定义为客户端图像映射。图像映射指的是带有可点击区域的图像。usemap 属性与  元素的 name 或 id 属性相关联。

这里通过 usemap 映射到 <map> 的circle形 <area>。

<area>标签类似<img>,是无法有子元素或其他子内容的。

  • shape表示点击热点区域的形状,支持矩形rect,圆形circle以及多边形poly。
  • 表示点击热点区域形状的坐标。圆形circle支持3个数值,前2个值为圆心坐标,第3个值为圆的半径大小。
  • href和<a>元素的href是一样的东西,直接跳转地址,或者锚点等。也同样支持target属性和rel属性。也就是说<area>可以看成是半个<a>元素。
  	

 

方法二:border-radius (css3)

设置div的border-radius:50%。

#circle{ background:red; width:100px; height:100px; border-radius:50%;}

 

方法三:

JS实现,获取鼠标点击位置坐标,判断其到圆点的距离是否不大于圆的半径,来判断点击位置是否在圆内。

两点之间的距离计算公式:  |AB| = Math.abs(Math.sqrt(Math.pow(X2-X1), 2) + Math.pow(Y2-Y1, 2)))

Math.abs()求绝对值,Math.pow(底数,指数),Math.sqrt()求平方根

// 获取目标元素var box = document.getElementById('box'); // 对目标元素target的圆形区域进行一个点击事件绑定function bindClickOnCircleArea(target, callback) {  target.onclick = function (e) {    e = e || window.event;     // target中心点的坐标    var x1 = 100;    var y1 = 100;     // 事件源坐标    var x2 = e.offsetX;    var y2 = e.offsetY;     // 校验是否在圆形点击区,在的话就执行callback回调    // 计算事件触发点与target中心的位置    var len = Math.abs(Math.sqrt(Math.pow(x2 - x1, 2) + Math.pow(y2 - y1, 2)));    // 通过半径进行校验    if (len <= 100) {      callback();    } else {      alert('在外面');    }  }} // 执行bindClickOnCircleArea(box, function () {  alert('找到了');});

 

转载地址:http://diuvi.baihongyu.com/

你可能感兴趣的文章
Android Design:原生TabLayout+viewpaper+fragment实现滑动效果
查看>>
第三方开源库:SlidingMenu-Master实现侧拉效果
查看>>
Android基础:startActivityForResult+onActivityResult+setResult
查看>>
异常:The selected device is incompatible
查看>>
第三方SDK:RongCloud IMKit实现简单的单人会话
查看>>
Android基础:button imageview
查看>>
Android Studio:Android Studio安装Genymotion插件
查看>>
第三方SDK:讯飞语音听写
查看>>
第三方SDK:JPush SDK Eclipse
查看>>
第三方开源库:imageLoader的使用
查看>>
Andriod基础:RatingBar设置
查看>>
自定义控件:飞入飞出的效果
查看>>
自定义控件:动态获取控件的高
查看>>
第三方开源库:nineoldandroid:ValueAnimator 动态设置textview的高
查看>>
第三方SDK:百度地图SDK的使用
查看>>
Android studio_迁移Eclipse项目到Android studio
查看>>
JAVA:Date简介和格式化
查看>>
Android UI:Spinner
查看>>
App开发:强制更新app
查看>>
Android Studio:签名并导包
查看>>