最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

用JavaScript实现使用鼠标画线的示例代码_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 21:26:19
文档

用JavaScript实现使用鼠标画线的示例代码_javascript技巧

用JavaScript实现使用鼠标画线的示例代码_javascript技巧: Untitled 1 .style1 { font-size: x-small; } /** 画点 */ function makedot(x, y){ pointDiv = ; return pointDiv; } /** 根据两点坐标画直线。 */ function line(x1,y1,x2,y2){ var slope; //
推荐度:
导读用JavaScript实现使用鼠标画线的示例代码_javascript技巧: Untitled 1 .style1 { font-size: x-small; } /** 画点 */ function makedot(x, y){ pointDiv = ; return pointDiv; } /** 根据两点坐标画直线。 */ function line(x1,y1,x2,y2){ var slope; //


 
 

 
 
Untitled 1 
 
 
/**
 画点
*/ 
function makedot(x, y){ 
 pointDiv = ""; 
 return pointDiv;
} 
/** 
 根据两点坐标画直线。 
*/ 

function line(x1,y1,x2,y2){ 
 var slope; //斜率
 var direction;//坐标运动方向
 var tx = x2 - x1;
 var ty = y2 - y1;
 if(tx == 0 && ty == 0)return;
 var points = "";
 var axis;//坐标轴上的坐标
 if(Math.abs(tx) >= Math.abs(ty)){//在x轴上移动
 direction = tx > 0 ? 1 : -1;
 tx = Math.abs(tx);
 slope = ty / tx;
 axis = x1;
 for(i = 0; i < tx; i ++){
 points += makedot(axis, y1 + i * slope);
 axis += direction;
 }
 
 }else{//在y轴上移动
 direction = ty > 0 ? 1 : -1;
 ty = Math.abs(ty);
 slope = tx / ty; 
 axis = y1; 
 for(i = 0; i < ty; i ++){
 points += makedot(x1 + i * slope, axis);
 axis += direction;
 }
 }
 var container = document.getElementById("container");
 container.innerHTML += points; 
} 
var oldPoint = null;
//获取鼠标位置
function mousePosition(ev){
 ev = ev || window.event;
 if(ev.pageX || ev.pageY){
 return {x:ev.pageX, y:ev.pageY};
 }
 var doc = document.documentElement, body = document.body;
 var pageX = event.clientX + (doc && doc.scrollLeft || body && body.scrollLeft || 0) - (doc && doc.clientLeft || body && body.clientLeft || 0);
 var pageY = event.clientY + (doc && doc.scrollTop || body && body.scrollTop || 0) - (doc && doc.clientTop || body && body.clientTop || 0); 
 return {x:pageX, y:pageY};
}

function recordPoint(ev){
 
 var point = mousePosition(ev);
 if(oldPoint != null){
 line(oldPoint.x, oldPoint.y, point.x, point.y);
 }
 oldPoint = point;
}

 

 

 

文档

用JavaScript实现使用鼠标画线的示例代码_javascript技巧

用JavaScript实现使用鼠标画线的示例代码_javascript技巧: Untitled 1 .style1 { font-size: x-small; } /** 画点 */ function makedot(x, y){ pointDiv = ; return pointDiv; } /** 根据两点坐标画直线。 */ function line(x1,y1,x2,y2){ var slope; //
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top