JS桌面應用

1、圖片預加載佈局

1     var oImg = new Image();
2     
3     oImg.onload=function(){
4         //alert('success');
5     }
6     oImg.onerror=function(){
7         alert('failture');
8     }
9     oImg.src='images/5.jpg';

 

2、仿google自定義首頁:集佈局轉換、拖拽、碰撞檢測、交換位置於一體this

  1     var oUl1=document.getElementById('ul1');
  2     var aLi=oUl1.getElementsByTagName('li');
  3     var aPos=[];
  4     var iMinZindex=2;//設置最小層級
  5     var i=0;
  6     //佈局轉換
  7     for(i=0;i<aLi.length;i++){
  8         aPos[i]={left:aLi[i].offsetLeft,top:aLi[i].offsetTop};//console.log(aPos);
  9     }
 10     for(i=0;i<aLi.length;i++){
 11         aLi[i].style.left=aPos[i].left+'px';
 12         aLi[i].style.top=aPos[i].top+'px';
 13         
 14         aLi[i].style.position='absolute';
 15         aLi[i].style.margin='0';
 16         aLi[i].index=i;
 17     }
 18     
 19     //拖拽
 20     for(i=0;i<aLi.length;i++){
 21         setDrag(aLi[i]);
 22     }
 23     function setDrag(obj){
 24         obj.onmousedown=function(ev){
 25             this.style.zIndex=iMinZindex++;//保證當前對象的層級最高
 26             var oEvent=ev||event;
 27             
 28             var disX=oEvent.clientX-obj.offsetLeft;
 29             var disY=oEvent.clientY-obj.offsetTop;
 30             
 31             document.onmousemove=function(ev){
 32                 var oEvent=ev||event;
 33                 
 34                 obj.style.left=oEvent.clientX-disX+'px';
 35                 obj.style.top=oEvent.clientY-disY+'px';
 36                 
 37                 for(i=0;i<aLi.length;i++){
 38                     aLi[i].className='';
 39                 }
 40                 
 41                 var oNear=findNearest(obj);
 42                 
 43                 if(oNear){
 44                     oNear.className='active';
 45                 }
 46                 /*for(i=0;i<aLi.length;i++){
 47                     if(obj==aLi[i]) continue;
 48                     if(cdTest(obj,aLi[i])){
 49                         aLi[i].className='active';
 50                     }else{
 51                         aLi[i].className='';
 52                     }
 53                 }*/
 54             };
 55             document.onmouseup=function(){
 56                 document.onmousemove=null;
 57                 document.onmouseup=null;
 58                 
 59                 var oNear=findNearest(obj);
 60                 
 61                 if(oNear){
 62                     /*oNear->obj
 63                     obj->oNear*/
 64                     oNear.className='';
 65                     
 66                     startMove(oNear,aPos[obj.index]);
 67                     startMove(obj,aPos[oNear.index]);
 68                     
 69                     var tmp=0;
 70                     
 71                     tmp=oNear.index;
 72                     oNear.index=obj.index;
 73                     obj.index=tmp;
 74                 }else{
 75                     startMove(obj,aPos[obj.index]);//aPos[obj.index]=={left:aPos[obj.index].left,top:aPos[obj.index].top}
 76                 }
 77             };
 78             
 79             return false;
 80             
 81         };
 82     }
 83     
 84     //碰撞檢測
 85     function cdTest(obj1,obj2){
 86         var l1=obj1.offsetLeft;
 87         var r1=obj1.offsetLeft+obj1.offsetWidth;
 88         var t1=obj1.offsetTop;
 89         var b1=obj1.offsetTop+obj1.offsetHeight;
 90         
 91         var l2=obj2.offsetLeft;
 92         var r2=obj2.offsetLeft+obj2.offsetWidth;
 93         var t2=obj2.offsetTop;
 94         var b2=obj2.offsetTop+obj2.offsetHeight;
 95         
 96         if(r1<l2 || l1>r2 || t1>b2 || b1<t2){
 97             return false;
 98         }else{
 99             return true;
100         }
101     }
102     
103     function getDis(obj1,obj2){
104         var a=obj1.offsetLeft-obj2.offsetLeft;
105         var b=obj1.offsetTop-obj2.offsetTop;
106         
107         return Math.sqrt(Math.pow(a,2)+Math.pow(b,2));
108     }
109     
110     function findNearest(obj){
111         var iMin=999999;
112         var iMinIndex=-1;
113         
114         for(i=0;i<aLi.length;i++){
115             if(obj==aLi[i]) continue;
116             
117             if(cdTest(obj,aLi[i])){
118                 var dis=getDis(obj,aLi[i]);
119                 
120                 if(iMin>dis){
121                     iMin=dis;
122                     iMinIndex=i;
123                 }
124             }
125         }
126         
127         if(iMinIndex==-1){
128             return null;
129         }else{
130             return aLi[iMinIndex];
131         }
132     }
133     
134     //運動
相關文章
相關標籤/搜索