JTrackBar水平拖動(dòng)效果
更新時(shí)間:2007年07月15日 00:00:00 作者:
<!--
/*
----------------------------------------------------------------------
JTrackBar
初始日期:2007/07/11
Author:xlingFairy
Blog:http://xling.blueidea.com
目前只能生水平的,垂直的還沒(méi)有寫。
設(shè)計(jì)功能:
當(dāng)改變時(shí),觸發(fā)事件onChange,并傳當(dāng)前值。
2007/07/12
加入拖動(dòng)功能。
2007/07/13
加入皮膚功能
未做功能:指定trackFrequence,你可以自己試著修改一下。
請(qǐng)尊重勞動(dòng)成果!不得刪除原作都信息!后果自負(fù)!
----------------------------------------------------------------------
*/
function JPos(){
}
JPos.getAbsPos = function(pTarget){
var _x = 0;
var _y = 0;
while(pTarget.offsetParent){
_x += pTarget.offsetLeft;
_y += pTarget.offsetTop;
pTarget = pTarget.offsetParent;
}
_x += pTarget.offsetLeft;
_y += pTarget.offsetTop;
return {x:_x,y:_y};
}
JPos.getMousePos = function(evt){
var _x,_y;
evt = evt || window.event;
if(evt.pageX || evt.pageY){
_x = evt.pageX;
_y = evt.pageY;
}else{
_x = evt.clientX + document.body.scrollLeft - document.body.clientLeft;
_y = evt.clientY + document.body.scrollTop - document.body.clientTop;
}
return {x:_x,y:_y};
}
function JTrackBar(pParent){
var self = this;
var $ = function(pId){
return document.getElementById(pId);
}
var $c = function(pTag){
return document.createElement(pTag);
}
var body = $(pParent) || document.body;
var oOutline = null;
var oTrackArea = null;
var oBtnPointer = null;
var oArrBtnLeft = oArrBtnRight = oArrBtnUp = oArrBtnDown = null;
var inDrag = false;
var dragStartPos = null;
var maxPosition = 100; //最大刻度
var minPosition = 0; //最小刻度
var position = 0; //當(dāng)前位置
var trackFrequence = 10; //點(diǎn)擊一次移動(dòng)多少刻度
this.setRange = function(pMin,pMax){
maxPosition = Math.max(pMin,pMax);
minPosition = Math.min(pMin,pMax);
}
var outlineWidth,trackAreaWidth,preFrequenceWidth;
this.onChange = new Function();
var getRunStyle = function(pObj,pProperty){
try{
if(pObj.currentStyle)
return eval("pObj.currentStyle." + pProperty);
else
return document.defaultView.getComputedStyle(pObj,"").getPropertyValue(pProperty);
}catch(e){
alert(e);
}
}
/*-----------------------------------------------------*/
var createOutline = function(pWidth){
oOutline = $c("DIV");
body.appendChild(oOutline);
oOutline.className = "JTrackBarStand";
oOutline.style.width = pWidth + "px";
//oOutline.style.height = "15px";
oOutline.style.overflow = "hidden";
}
/*-----------------------------------------------------*/
var createArrBtn = function(pDirection){
var arrBtn = $c("DIV");
switch(pDirection){
case "LEFT":
arrBtn.className = "btnLeft";
arrBtn.style.styleFloat = "left";
arrBtn.style.cssFloat = "left";
break;
case "RIGHT":
arrBtn.className = "btnRight";
arrBtn.style.styleFloat = "left";
arrBtn.style.cssFloat = "left";
break;
case "UP":
arrBtn.className = "btnUp";
break;
case "DOWN":
arrBtn.className = "btnDown";
break;
}
arrBtn.direction = pDirection;
arrBtn.onclick = arrBtn_click;
return arrBtn;
}
var arrBtn_click = function(evt){
evt = window.event || evt;
var o = evt.srcElement || evt.target;
switch(o.direction){
case "LEFT":
if(position <= minPosition)
return;
self.setPositionBy( -trackFrequence);
break;
case "RIGHT":
if(position >= maxPosition)
return;
self.setPositionBy(trackFrequence);
break;
}
}
var trackarea_click = function(evt){
evt = window.event || evt;
var mPos = JPos.getMousePos(evt);
var pos_ = JPos.getAbsPos(oTrackArea);
var w_ = parseInt(getRunStyle(oBtnPointer,"width"));
self.setPosition(parseInt((mPos.x - pos_.x) / preFrequenceWidth));
}
var createHTrackArea = function(){
var w_ = parseInt(getRunStyle(oArrBtnLeft,"width"));
trackAreaWidth = outlineWidth - 2 * w_;
preFrequenceWidth = trackAreaWidth / (maxPosition - minPosition);
oTrackArea = $c("DIV");
oOutline.appendChild(oTrackArea);
oTrackArea.onclick = trackarea_click;
oTrackArea.className = "trackArea";
oTrackArea.style.width = trackAreaWidth + "px";
oTrackArea.style.styleFloat = "left";
oTrackArea.style.cssFloat = "left";
}
var recalcTrackArea = function(){
var w_ = parseInt(getRunStyle(oArrBtnLeft,"width"));
trackAreaWidth = outlineWidth - 2 * w_;
preFrequenceWidth = trackAreaWidth / (maxPosition - minPosition);
oTrackArea.style.width = trackAreaWidth + "px";
}
var pointer_mousedown = function(evt){
inDrag = true;
dragStartPos = JPos.getMousePos(evt);
body.onmousemove = pointer_mousemove;
body.onmouseup = pointer_mouseup;
body.onmouseout = pointer_mouseout;
}
var pointer_mousemove = function(evt){
if(!inDrag) return;
//evt = window.event || evt;
//var x_ = evt.clientX;
//window.status = x_ + " " + dragStartPos.x;
//self.setPositionBy(x_ - dragStartPos.x);
//window.status += " " + evt.clientX;
var mPos = JPos.getMousePos(evt);
var pos_ = JPos.getAbsPos(oTrackArea);
self.setPosition(parseInt((mPos.x - pos_.x) / preFrequenceWidth));
}
var pointer_mouseup = function(){
inDrag = false;
}
var pointer_mouseout = function(){
//inDrag = false;
}
var createHPointer = function(){
oBtnPointer = $c("DIV");
oOutline.appendChild(oBtnPointer);
//oBtnPointer.onclick = trackarea_click;
oBtnPointer.onmousedown = pointer_mousedown;
//oOutline.onmousemove = oBtnPointer.onmousemove = pointer_mousemove;
//oBtnPointer.onmouseup = pointer_mouseup;
//oBtnPointer.onmouseout = pointer_mouseout;
oBtnPointer.className = "btnPointer";
oBtnPointer.style.position = "absolute";
var w_ = parseInt(getRunStyle(oBtnPointer,"width"));
var pos_ = JPos.getAbsPos(oTrackArea);
oBtnPointer.style.left = pos_.x - w_/2 + "px";
oBtnPointer.style.top = pos_.y + "px";
oBtnPointer.style.cssText += "left:" + (pos_.x - w_/2) + "px;top:" + pos_.y + "px;";
}
/*-----------------------------------------------------*/
this.createHTrackBar = function(pWidth){
outlineWidth = pWidth;
createOutline(pWidth);
oArrBtnLeft = createArrBtn("LEFT");
oOutline.appendChild(oArrBtnLeft);
createHTrackArea();
oArrBtnRight = createArrBtn("RIGHT");
oOutline.appendChild(oArrBtnRight);
createHPointer();
}
/*-----------------------------------------------------*/
this.setPositionBy = function(pPosition){
position += pPosition;
self.setPosition(position);
}
this.setPosition = function(pPosition){
position = pPosition;
if(position > maxPosition)
position = maxPosition;
if(position < minPosition)
position = minPosition;
var pos_ = JPos.getAbsPos(oTrackArea);
var w_ = parseInt(getRunStyle(oBtnPointer,"width"));
oBtnPointer.style.left = pos_.x - w_/2 + preFrequenceWidth * position + "px";
doChange();
}
var doChange = function(){
self.onChange(position);
}
this.getPosition = function(){
return position;
}
this.setSkin = function(pSkin){
oOutline.className = pSkin;
recalcTrackArea();
}
}
打包文件下載
/*
----------------------------------------------------------------------
JTrackBar
初始日期:2007/07/11
Author:xlingFairy
Blog:http://xling.blueidea.com
目前只能生水平的,垂直的還沒(méi)有寫。
設(shè)計(jì)功能:
當(dāng)改變時(shí),觸發(fā)事件onChange,并傳當(dāng)前值。
2007/07/12
加入拖動(dòng)功能。
2007/07/13
加入皮膚功能
未做功能:指定trackFrequence,你可以自己試著修改一下。
請(qǐng)尊重勞動(dòng)成果!不得刪除原作都信息!后果自負(fù)!
----------------------------------------------------------------------
*/
function JPos(){
}
JPos.getAbsPos = function(pTarget){
var _x = 0;
var _y = 0;
while(pTarget.offsetParent){
_x += pTarget.offsetLeft;
_y += pTarget.offsetTop;
pTarget = pTarget.offsetParent;
}
_x += pTarget.offsetLeft;
_y += pTarget.offsetTop;
return {x:_x,y:_y};
}
JPos.getMousePos = function(evt){
var _x,_y;
evt = evt || window.event;
if(evt.pageX || evt.pageY){
_x = evt.pageX;
_y = evt.pageY;
}else{
_x = evt.clientX + document.body.scrollLeft - document.body.clientLeft;
_y = evt.clientY + document.body.scrollTop - document.body.clientTop;
}
return {x:_x,y:_y};
}
function JTrackBar(pParent){
var self = this;
var $ = function(pId){
return document.getElementById(pId);
}
var $c = function(pTag){
return document.createElement(pTag);
}
var body = $(pParent) || document.body;
var oOutline = null;
var oTrackArea = null;
var oBtnPointer = null;
var oArrBtnLeft = oArrBtnRight = oArrBtnUp = oArrBtnDown = null;
var inDrag = false;
var dragStartPos = null;
var maxPosition = 100; //最大刻度
var minPosition = 0; //最小刻度
var position = 0; //當(dāng)前位置
var trackFrequence = 10; //點(diǎn)擊一次移動(dòng)多少刻度
this.setRange = function(pMin,pMax){
maxPosition = Math.max(pMin,pMax);
minPosition = Math.min(pMin,pMax);
}
var outlineWidth,trackAreaWidth,preFrequenceWidth;
this.onChange = new Function();
var getRunStyle = function(pObj,pProperty){
try{
if(pObj.currentStyle)
return eval("pObj.currentStyle." + pProperty);
else
return document.defaultView.getComputedStyle(pObj,"").getPropertyValue(pProperty);
}catch(e){
alert(e);
}
}
/*-----------------------------------------------------*/
var createOutline = function(pWidth){
oOutline = $c("DIV");
body.appendChild(oOutline);
oOutline.className = "JTrackBarStand";
oOutline.style.width = pWidth + "px";
//oOutline.style.height = "15px";
oOutline.style.overflow = "hidden";
}
/*-----------------------------------------------------*/
var createArrBtn = function(pDirection){
var arrBtn = $c("DIV");
switch(pDirection){
case "LEFT":
arrBtn.className = "btnLeft";
arrBtn.style.styleFloat = "left";
arrBtn.style.cssFloat = "left";
break;
case "RIGHT":
arrBtn.className = "btnRight";
arrBtn.style.styleFloat = "left";
arrBtn.style.cssFloat = "left";
break;
case "UP":
arrBtn.className = "btnUp";
break;
case "DOWN":
arrBtn.className = "btnDown";
break;
}
arrBtn.direction = pDirection;
arrBtn.onclick = arrBtn_click;
return arrBtn;
}
var arrBtn_click = function(evt){
evt = window.event || evt;
var o = evt.srcElement || evt.target;
switch(o.direction){
case "LEFT":
if(position <= minPosition)
return;
self.setPositionBy( -trackFrequence);
break;
case "RIGHT":
if(position >= maxPosition)
return;
self.setPositionBy(trackFrequence);
break;
}
}
var trackarea_click = function(evt){
evt = window.event || evt;
var mPos = JPos.getMousePos(evt);
var pos_ = JPos.getAbsPos(oTrackArea);
var w_ = parseInt(getRunStyle(oBtnPointer,"width"));
self.setPosition(parseInt((mPos.x - pos_.x) / preFrequenceWidth));
}
var createHTrackArea = function(){
var w_ = parseInt(getRunStyle(oArrBtnLeft,"width"));
trackAreaWidth = outlineWidth - 2 * w_;
preFrequenceWidth = trackAreaWidth / (maxPosition - minPosition);
oTrackArea = $c("DIV");
oOutline.appendChild(oTrackArea);
oTrackArea.onclick = trackarea_click;
oTrackArea.className = "trackArea";
oTrackArea.style.width = trackAreaWidth + "px";
oTrackArea.style.styleFloat = "left";
oTrackArea.style.cssFloat = "left";
}
var recalcTrackArea = function(){
var w_ = parseInt(getRunStyle(oArrBtnLeft,"width"));
trackAreaWidth = outlineWidth - 2 * w_;
preFrequenceWidth = trackAreaWidth / (maxPosition - minPosition);
oTrackArea.style.width = trackAreaWidth + "px";
}
var pointer_mousedown = function(evt){
inDrag = true;
dragStartPos = JPos.getMousePos(evt);
body.onmousemove = pointer_mousemove;
body.onmouseup = pointer_mouseup;
body.onmouseout = pointer_mouseout;
}
var pointer_mousemove = function(evt){
if(!inDrag) return;
//evt = window.event || evt;
//var x_ = evt.clientX;
//window.status = x_ + " " + dragStartPos.x;
//self.setPositionBy(x_ - dragStartPos.x);
//window.status += " " + evt.clientX;
var mPos = JPos.getMousePos(evt);
var pos_ = JPos.getAbsPos(oTrackArea);
self.setPosition(parseInt((mPos.x - pos_.x) / preFrequenceWidth));
}
var pointer_mouseup = function(){
inDrag = false;
}
var pointer_mouseout = function(){
//inDrag = false;
}
var createHPointer = function(){
oBtnPointer = $c("DIV");
oOutline.appendChild(oBtnPointer);
//oBtnPointer.onclick = trackarea_click;
oBtnPointer.onmousedown = pointer_mousedown;
//oOutline.onmousemove = oBtnPointer.onmousemove = pointer_mousemove;
//oBtnPointer.onmouseup = pointer_mouseup;
//oBtnPointer.onmouseout = pointer_mouseout;
oBtnPointer.className = "btnPointer";
oBtnPointer.style.position = "absolute";
var w_ = parseInt(getRunStyle(oBtnPointer,"width"));
var pos_ = JPos.getAbsPos(oTrackArea);
oBtnPointer.style.left = pos_.x - w_/2 + "px";
oBtnPointer.style.top = pos_.y + "px";
oBtnPointer.style.cssText += "left:" + (pos_.x - w_/2) + "px;top:" + pos_.y + "px;";
}
/*-----------------------------------------------------*/
this.createHTrackBar = function(pWidth){
outlineWidth = pWidth;
createOutline(pWidth);
oArrBtnLeft = createArrBtn("LEFT");
oOutline.appendChild(oArrBtnLeft);
createHTrackArea();
oArrBtnRight = createArrBtn("RIGHT");
oOutline.appendChild(oArrBtnRight);
createHPointer();
}
/*-----------------------------------------------------*/
this.setPositionBy = function(pPosition){
position += pPosition;
self.setPosition(position);
}
this.setPosition = function(pPosition){
position = pPosition;
if(position > maxPosition)
position = maxPosition;
if(position < minPosition)
position = minPosition;
var pos_ = JPos.getAbsPos(oTrackArea);
var w_ = parseInt(getRunStyle(oBtnPointer,"width"));
oBtnPointer.style.left = pos_.x - w_/2 + preFrequenceWidth * position + "px";
doChange();
}
var doChange = function(){
self.onChange(position);
}
this.getPosition = function(){
return position;
}
this.setSkin = function(pSkin){
oOutline.className = pSkin;
recalcTrackArea();
}
}
打包文件下載
相關(guān)文章
js實(shí)現(xiàn)鼠標(biāo)滑過(guò)文字鏈接色彩變化的效果
這篇文章主要介紹了js實(shí)現(xiàn)鼠標(biāo)滑過(guò)文字鏈接色彩變化的效果,涉及javascript鼠標(biāo)事件及樣式操作的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-05-05
純JS實(shí)現(xiàn)監(jiān)控本地文件變化
你是否曾夢(mèng)想擁有一個(gè)能夠?qū)崟r(shí)監(jiān)控本地文件變化的網(wǎng)頁(yè)應(yīng)用,現(xiàn)在,這個(gè)夢(mèng)想即將成為現(xiàn)實(shí),本文將通過(guò)純JS實(shí)現(xiàn)這一功能,感興趣的小伙伴可以了解下2025-04-04
javascript 包裹節(jié)點(diǎn) 提高效率
模仿jQuery,創(chuàng)建幾個(gè)包裹節(jié)點(diǎn)的方法,發(fā)現(xiàn)jQuery的方法很低效啊,下一次他又可以說(shuō)這幾個(gè)方法可以提升了多少多少了。2010-02-02
ZeroClipboard.js使用一個(gè)flash復(fù)制多個(gè)文本框
這篇文章主要為大家詳細(xì)介紹了ZeroClipboard.js使用一個(gè)flash復(fù)制多個(gè)文本框,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
JavaScript實(shí)現(xiàn)有限狀態(tài)機(jī)的示例代碼
有限狀態(tài)機(jī)(Finite?State?Machine,?FSM)是一種數(shù)學(xué)模型,用于描述系統(tǒng)在不同狀態(tài)下的行為,本文給大家介紹JavaScript實(shí)現(xiàn)有限狀態(tài)機(jī)的示例代碼,感興趣的朋友一起看看吧2024-12-12
JavaScript兩個(gè)變量交換值的實(shí)現(xiàn)方法
本文主要介紹了JavaScript兩個(gè)變量交換值(不使用臨時(shí)變量)的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-03-03
JS實(shí)現(xiàn)關(guān)鍵字搜索時(shí)的相關(guān)下拉字段效果
關(guān)鍵字搜索時(shí)有下拉字段,在使用百度時(shí)會(huì)遇到,本例講述用js實(shí)現(xiàn)類似的效果2014-08-08

