该组件实现了根据箭头起止点坐标画箭头功能。目前组件可设置箭头形状(大小和角度)。

样例:

废话少说,直接上代码:

arrow.js

/** * 实现两点间画箭头的功能 * @author mapleque@163.com * @version 1.0 * @date 2013.05.23 */;(function(window,document){ if (window.mapleque==undefined) window.mapleque={}; if (window.mapleque.arrow!=undefined) return;  /** * 组件对外接口 */ var proc={ /** * 接收canvas对象,并在此上画箭头(箭头起止点已经设置) * @param context */ paint:function(context){paint(this,context);}, /** * 设置箭头起止点 * @param sp起点 * @param ep终点 * @param st强度 */ set:function(sp,ep,st){init(this,sp,ep,st);}, /** * 设置箭头外观 * @param args */ setPara:function(args){  this.size=args.arrow_size;//箭头大小  this.sharp=args.arrow_sharp;//箭头锐钝 } };  var init=function(a,sp,ep,st){ a.sp=sp;//起点 a.ep=ep;//终点 a.st=st;//强度 }; var paint=function(a,context){ var sp=a.sp; var ep=a.ep; if (context==undefined)  return; //画箭头主线 context.beginPath(); context.moveTo(sp.x,sp.y); context.lineTo(ep.x,ep.y); //画箭头头部 var h=_calcH(a,sp,ep,context); context.moveTo(ep.x,ep.y); context.lineTo(h.h1.x,h.h1.y); context.moveTo(ep.x,ep.y); context.lineTo(h.h2.x,h.h2.y); context.stroke(); }; //计算头部坐标 var _calcH=function(a,sp,ep,context){ var theta=Math.atan((ep.x-sp.x)/(ep.y-sp.y)); var cep=_scrollXOY(ep,-theta); var csp=_scrollXOY(sp,-theta); var ch1={x:0,y:0}; var ch2={x:0,y:0}; var l=cep.y-csp.y; ch1.x=cep.x+l*(a.sharp||0.025); ch1.y=cep.y-l*(a.size||0.05); ch2.x=cep.x-l*(a.sharp||0.025); ch2.y=cep.y-l*(a.size||0.05); var h1=_scrollXOY(ch1,theta); var h2=_scrollXOY(ch2,theta); return {  h1:h1,  h2:h2  }; }; //坐标 var _scrollXOY=function(p,theta){ return {  x:p.x*Math.cos(theta)+p.y*Math.sin(theta),  y:p.y*Math.cos(theta)-p.x*Math.sin(theta) }; };  var arrow=new Function(); arrow.prototype=proc; window.mapleque.arrow=arrow;})(window,document);

arrow.html

<!DOCTYPE html><html><head><meta charset="UTF-8"><title>sample of the arrow</title><script type="text/javascript" src="./arrow.js"></script></head><body><canvas width=800 height=600 id="arrowLine">请使用支持HTML5的浏览器</canvas><script type="text/javascript">var cont=document.getElementById("arrowLine").getContext('2d');var a1=new window.mapleque.arrow();a1.set({x:350,y:300},{x:200,y:200});a1.paint(cont);var a2=new window.mapleque.arrow();a2.set({x:100,y:100},{x:200,y:250});a2.paint(cont);var a3=new window.mapleque.arrow();a3.set({x:100,y:300},{x:150,y:150});a3.paint(cont);var a4=new window.mapleque.arrow();a4.set({x:350,y:150},{x:150,y:250});a4.setPara({ arrow_size:0.5, arrow_sharp:0.5})a4.paint(cont);</script></body></html>
最新资讯
美司法部控告六人涉嫌贿赂亚马逊员工以获得市场优势

美司法部控告六人涉嫌

据报道,美国司法部周五指控六人参与贿赂亚马逊员工和承
最新发现的一次大灭绝事件

最新发现的一次大灭绝

2.33亿年前,地球成为“炼狱”。在我们现在所知的加拿大
拯救替罪羊,科学能帮到我们什么?

拯救替罪羊,科学能帮到

被错误指控的人,即使最终能洗脱罪名,通常也需要多年的等
恒大汽车要登陆科创板:汽车尚未卖一辆 已聚集了许家印马云马化腾

恒大汽车要登陆科创板

恒大汽车董事会宣布决议,拟发行人民币股份于上交所科创
才貌双全的清华女神教授,2020年又拿奖,却说只想“任性”地活

才貌双全的清华女神教

距颜宁2017年辞去清华大学教授,已经过去了三年。看起来
爱立信同意11亿美元收购美5G方案商Cradlepoint

爱立信同意11亿美元收

瑞典电信设备制造商爱立信表示,它已同意以11亿美元的价
最新文章
详解Vue的ref特性的使用

详解Vue的ref特性的使

这篇文章主要介绍了详解Vue的ref特性的使用,文中通过
vue学习笔记之slot插槽基本用法实例分析

vue学习笔记之slot插

这篇文章主要介绍了vue学习笔记之slot插槽基本用法,结
vue跳转方式(打开新页面)及传参操作示例

vue跳转方式(打开新页

这篇文章主要介绍了vue跳转方式(打开新页面)及传参操作,
vue学习笔记之过滤器的基本使用方法实例分析

vue学习笔记之过滤器

这篇文章主要介绍了vue学习笔记之过滤器的基本使用方
js获取本日、本周、本月的时间代码

js获取本日、本周、本

本篇文章给大家分享的内容是利用js如何获取本日、本周
node crawler如何添加promise支持

node crawler如何添加

这篇文章主要介绍了node crawler如何添加promise支持,