用JavaScript實現(xiàn)使用鼠標畫線的示例代碼
更新時間:2014年08月19日 17:07:44 投稿:whsnow
用JavaScript實現(xiàn)用鼠標畫線,具體步驟是首先是畫點,在根據(jù)兩點坐標畫直線,最后是獲取鼠標位置,需要的朋友可以參考下
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled 1</title>
<style type="text/css">
.style1 {
font-size: x-small;
}
</style>
<script type="text/javascript">
/**
畫點
*/
function makedot(x, y){
pointDiv = "<div style='height:1px;position:absolute;left:" + x +
"px;top:" + y + "px;width:1px;background:#f00;overflow:hidden'></div>";
return pointDiv;
}
/**
根據(jù)兩點坐標畫直線。
*/
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;
}
</script>
</head>
<body>
<div id="container" style="width: 1000px; height: 600px; border:1px #bfbfbf solid;" onclick="recordPoint(event);">
</div>
<script type="text/javascript">
//line(19,19,22,300);
</script>
</body>
</html>
您可能感興趣的文章:
- JavaScript實現(xiàn)鼠標滑過處生成氣泡的方法
- javascript實現(xiàn)圖片跟隨鼠標移動效果的方法
- JavaScript實現(xiàn)鼠標點擊后層展開效果的方法
- 最精簡的JavaScript實現(xiàn)鼠標拖動效果的方法
- javascript實時獲取鼠標坐標值并顯示的方法
- javascript實現(xiàn)鼠標拖動改變層大小的方法
- JavaScript實現(xiàn)鼠標滑過圖片變換效果的方法
- javascript實現(xiàn)簡單的鼠標拖動效果實例
- javascript獲取當前鼠標坐標的方法
- JavaScript中獲取鼠標位置相關(guān)屬性總結(jié)
- JavaScript檢測鼠標移動方向的方法
相關(guān)文章
網(wǎng)頁開發(fā)中的容易忽略的問題 javascript HTML中的table
最近在搞在線電子表格這個東西,下面的是使用中的一些知識技巧。2009-04-04
JavaScript數(shù)據(jù)類型轉(zhuǎn)換簡單方法舉例
JavaScript是一種無類型語言,但同時JavaScript提供了一種靈活的自動類型轉(zhuǎn)換的處理方式,下面這篇文章主要給大家介紹了關(guān)于JavaScript數(shù)據(jù)類型轉(zhuǎn)換的相關(guān)資料,需要的朋友可以參考下2023-12-12
Javascript 生成指定范圍數(shù)值隨機數(shù)
查手冊后才知道, 介紹的信息少得可憐吶, 沒有介紹生成 m-n 范圍的隨機數(shù)..., 就只是給你一個 Math.random() 了事.2009-01-01
解決Js先觸發(fā)失去焦點事件再執(zhí)行點擊事件的問題
今天小編就為大家分享一篇解決Js先觸發(fā)失去焦點事件再執(zhí)行點擊事件的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08

