This commit is contained in:
libccy 2017-02-11 14:03:12 +08:00
parent 540a4e438a
commit 1f4b70149e
1 changed files with 291 additions and 23 deletions

View File

@ -20930,9 +20930,10 @@
for(var i=0;i<game.players.length;i++){ for(var i=0;i<game.players.length;i++){
game.players[i].unprompt(); game.players[i].unprompt();
} }
while(_status.dragline.length){ for(var i=0;i<_status.dragline.length;i++){
_status.dragline.shift().delete(); if(_status.dragline[i]) _status.dragline[i].remove();
} }
_status.dragline.length=0;
}, },
swapSeat:function(player1,player2,prompt,behind){ swapSeat:function(player1,player2,prompt,behind){
if(behind){ if(behind){
@ -30866,9 +30867,8 @@
if(_status.mousedragging&&e.touches.length){ if(_status.mousedragging&&e.touches.length){
e.preventDefault(); e.preventDefault();
var items=document.elementsFromPoint(e.touches[0].clientX,e.touches[0].clientY); var item=document.elementFromPoint(e.touches[0].clientX,e.touches[0].clientY);
for(var i=0;i<items.length;i++){ while(item){
var item=items[i];
if(lib.config.enable_touchdragline&&_status.mouseleft&&!game.chess){ if(lib.config.enable_touchdragline&&_status.mouseleft&&!game.chess){
ui.canvas.width=ui.arena.offsetWidth; ui.canvas.width=ui.arena.offsetWidth;
ui.canvas.height=ui.arena.offsetHeight; ui.canvas.height=ui.arena.offsetHeight;
@ -31009,11 +31009,209 @@
} }
return; return;
} }
item=item.parentNode;
} }
_status.mouseleft=true; _status.mouseleft=true;
_status.dragstatuschanged=null; _status.dragstatuschanged=null;
} }
}, },
windowtouchmove_tmp:function(e){
e.preventDefault();
if(window.inSplash) return;
if(_status.draggingroundmenu){
delete _status._swipeorigin;
if(ui.roundmenu._dragorigin&&ui.roundmenu._dragtransform&&e.touches.length){
var translate=ui.roundmenu._dragtransform.slice(0);
var dx=e.touches[0].clientX/game.documentZoom-ui.roundmenu._dragorigin.clientX/game.documentZoom;
var dy=e.touches[0].clientY/game.documentZoom-ui.roundmenu._dragorigin.clientY/game.documentZoom;
translate[0]+=dx;
translate[1]+=dy;
if(dx*dx+dy*dy>100){
if(ui.roundmenu._resetTimeout){
clearTimeout(ui.roundmenu._resetTimeout);
delete ui.roundmenu._resetTimeout;
}
}
ui.roundmenu._dragtouches=e.touches[0];
ui.click.checkroundtranslate(translate);
}
_status.clicked=true;
}
else if(_status.draggingtouchdialog){
delete _status._swipeorigin;
if(_status.draggingtouchdialog._dragorigin&&_status.draggingtouchdialog._dragtransform&&e.touches.length){
var translate=_status.draggingtouchdialog._dragtransform.slice(0);
var dx=e.touches[0].clientX/game.documentZoom-_status.draggingtouchdialog._dragorigin.clientX/game.documentZoom;
var dy=e.touches[0].clientY/game.documentZoom-_status.draggingtouchdialog._dragorigin.clientY/game.documentZoom;
translate[0]+=dx;
translate[1]+=dy;
_status.draggingtouchdialog._dragtouches=e.touches[0];
ui.click.checkdialogtranslate(translate,_status.draggingtouchdialog);
}
_status.clicked=true;
}
else if(_status._swipeorigin&&e.touches[0]){
_status._swipeorigin.touches=e.touches[0];
}
if(_status.mousedragging&&e.touches.length){
e.preventDefault();
var items,item,iwhile,item0;
if(document.elementsFromPoint){
items=document.elementsFromPoint(e.touches[0].clientX,e.touches[0].clientY);
}
else{
item0=document.elementFromPoint(e.touches[0].clientX,e.touches[0].clientY);
}
if(items){
iwhile=0;
item=items[0];
}
else{
item=item0;
}
while(item){
if(lib.config.enable_touchdragline&&_status.mouseleft&&!game.chess){
var i=0;
var startPoint0=[_status.mousedragging.clientX/game.documentZoom-ui.arena.offsetLeft,_status.mousedragging.clientY/game.documentZoom-ui.arena.offsetTop];
var startPoint=startPoint0;
var endPoint;
if(_status.multitarget){
for(;i<_status.lastdragchange.length;i++){
var exy=_status.lastdragchange[i]._lastdragchange;
endPoint=[exy[0],exy[1]];
_status.dragline[i]=game.linexy(startPoint.concat(endPoint),'drag',_status.dragline[i]);
startPoint=endPoint;
}
}
if(!_status.selectionfull){
endPoint=[e.touches[0].clientX/game.documentZoom-ui.arena.offsetLeft,e.touches[0].clientY/game.documentZoom-ui.arena.offsetTop];
_status.dragline[i]=game.linexy(startPoint.concat(endPoint),'drag',_status.dragline[i]);
startPoint=endPoint;
i++;
}
if(!_status.multitarget){
for(;i<_status.lastdragchange.length;i++){
var exy=_status.lastdragchange[i]._lastdragchange;
_status.dragline[i]=game.linexy(startPoint0.concat([exy[0],exy[1]]),'drag',_status.dragline[i]);
}
}
var remained=_status.dragline.splice(i);
while(remained.length){
remained.shift().remove();
}
// ui.canvas.width=ui.arena.offsetWidth;
// ui.canvas.height=ui.arena.offsetHeight;
// var ctx=ui.ctx;
// ctx.shadowBlur=5;
// ctx.shadowColor='rgba(0,0,0,0.3)';
// ctx.strokeStyle='white';
// ctx.lineWidth=3;
// ctx.setLineDash([8,2]);
//
// ctx.beginPath();
//
// ctx.moveTo(_status.mousedragging.clientX/game.documentZoom-ui.arena.offsetLeft,_status.mousedragging.clientY/game.documentZoom-ui.arena.offsetTop);
//
// if(_status.multitarget){
// for(var i=0;i<_status.lastdragchange.length;i++){
// var exy=_status.lastdragchange[i]._lastdragchange;
// ctx.lineTo(exy[0],exy[1]);
// }
// }
// if(!_status.selectionfull){
// ctx.lineTo(e.touches[0].clientX/game.documentZoom-ui.arena.offsetLeft,e.touches[0].clientY/game.documentZoom-ui.arena.offsetTop);
// }
// ctx.stroke();
// if(!_status.multitarget){
// for(var i=0;i<_status.lastdragchange.length;i++){
// ctx.moveTo(_status.mousedragging.clientX/game.documentZoom-ui.arena.offsetLeft,_status.mousedragging.clientY/game.documentZoom-ui.arena.offsetTop);
// var exy=_status.lastdragchange[i]._lastdragchange;
// ctx.lineTo(exy[0],exy[1]);
// ctx.stroke();
// }
// }
}
if(item==_status.mousedragorigin){
if(_status.mouseleft){
_status.mousedragging=null;
_status.mousedragorigin=null;
_status.clicked=false;
game.uncheck();
game.check();
_status.clicked=true;
}
return;
}
var itemtype=get.itemtype(item);
if(itemtype=='card'||itemtype=='button'||itemtype=='player'){
if(items) _status.mouseleft=true;
var ex=e.touches[0].clientX/game.documentZoom-ui.arena.offsetLeft;
var ey=e.touches[0].clientY/game.documentZoom-ui.arena.offsetTop;
var exx=ex,eyy=ey;
if(game.chess){
ex-=-ui.chessContainer.scrollLeft+ui.chess.offsetLeft;
ey-=-ui.chessContainer.scrollTop+ui.chess.offsetTop;
}
if(itemtype!='player'||(ex>item.offsetLeft&&ex<item.offsetLeft+item.offsetWidth&&
ey>item.offsetTop&&ey<item.offsetTop+item.offsetHeight)){
var targetfixed=false;
if(itemtype=='player'){
if(get.select(_status.event.selectTarget)[1]==-1){
targetfixed=true;
}
}
if(!targetfixed&&item.classList.contains('selectable')&&_status.dragstatuschanged!=item){
if(items) _status.mouseleft=true;
_status.dragstatuschanged=item;
_status.clicked=false;
_status.dragged=false;
var notbefore=itemtype=='player'&&!item.classList.contains('selected');
ui.click[itemtype].call(item);
if(item.classList.contains('selected')){
if(notbefore){
_status.lastdragchange.push(item);
item._lastdragchange=[exx,eyy];
}
}
else{
_status.lastdragchange.remove(item);
for(var i=0;i<ui.touchlines.length;i++){
if(ui.touchlines[i]._origin==item){
ui.touchlines[i].delete();
ui.touchlines.splice(i--,1);
}
}
}
_status.selectionfull=true;
if(_status.event.filterButton&&ui.selected.buttons.length<get.select(_status.event.selectButton)[1]){
_status.selectionfull=false;
}
else if(_status.event.filterCard&&ui.selected.cards.length<get.select(_status.event.selectCard)[1]){
_status.selectionfull=false;
}
else if(_status.event.filterTarget&&ui.selected.targets.length<get.select(_status.event.selectTarget)[1]){
_status.selectionfull=false;
}
}
}
return;
}
if(items){
iwhile++
item=items[iwhile];
}
else{
item=item.parentNode;
}
}
if(items) _status.mouseleft=true;
_status.dragstatuschanged=null;
}
},
windowtouchend:function(e){ windowtouchend:function(e){
if(window.inSplash) return; if(window.inSplash) return;
if(e.touches.length==1&&!_status.dragged&&!_status.draggingtouchdialog){ if(e.touches.length==1&&!_status.dragged&&!_status.draggingtouchdialog){
@ -31198,7 +31396,13 @@
dialogs[i].delete(); dialogs[i].delete();
} }
var node=_status.currentmouseenter; var node=_status.currentmouseenter;
var items=document.elementsFromPoint(e.clientX,e.clientY); var items,item,iwhile,item0;
if(document.elementsFromPoint){
items=document.elementsFromPoint(e.clientX,e.clientY);
}
else{
item0=document.elementFromPoint(e.clientX,e.clientY);
}
if(_status.mousedragging){ if(_status.mousedragging){
e.preventDefault(); e.preventDefault();
if(lib.config.enable_dragline){ if(lib.config.enable_dragline){
@ -31221,12 +31425,16 @@
i++; i++;
} }
if(!_status.multitarget){ if(!_status.multitarget){
for(;i<_status.lastdragchange.length;i++){ for(var j=0;j<_status.lastdragchange.length;j++){
var exy=_status.lastdragchange[i]._lastdragchange; i+=j;
var exy=_status.lastdragchange[j]._lastdragchange;
_status.dragline[i]=game.linexy(startPoint0.concat([exy[0],exy[1]]),'drag',_status.dragline[i]); _status.dragline[i]=game.linexy(startPoint0.concat([exy[0],exy[1]]),'drag',_status.dragline[i]);
} }
} }
_status.dragline.splice(i); var remained=_status.dragline.splice(i+1);
for(var j=0;j<remained.length;j++){
if(remained[j]) remained[j].remove();
}
// ui.canvas.width=ui.arena.offsetWidth; // ui.canvas.width=ui.arena.offsetWidth;
// ui.canvas.height=ui.arena.offsetHeight; // ui.canvas.height=ui.arena.offsetHeight;
@ -31260,10 +31468,16 @@
// } // }
} }
for(var i=0;i<items.length;i++){ if(items){
var item=items[i]; iwhile=0;
item=items[0];
}
else{
item=item0;
}
while(item){
if(item==_status.mousedragorigin){ if(item==_status.mousedragorigin){
if(_status.mouseleft){ if((items&&_status.mouseleft)||(!items&&get.utc()-_status.lastmouseutc>=1000)){
_status.mousedragging=null; _status.mousedragging=null;
_status.mousedragorigin=null; _status.mousedragorigin=null;
_status.clicked=false; _status.clicked=false;
@ -31275,7 +31489,7 @@
} }
var itemtype=get.itemtype(item); var itemtype=get.itemtype(item);
if(itemtype=='card'||itemtype=='button'||itemtype=='player'){ if(itemtype=='card'||itemtype=='button'||itemtype=='player'){
_status.mouseleft=true; if(items) _status.mouseleft=true;
var ex=e.clientX/game.documentZoom-ui.arena.offsetLeft; var ex=e.clientX/game.documentZoom-ui.arena.offsetLeft;
var ey=e.clientY/game.documentZoom-ui.arena.offsetTop; var ey=e.clientY/game.documentZoom-ui.arena.offsetTop;
var exx=ex,eyy=ey; var exx=ex,eyy=ey;
@ -31292,7 +31506,7 @@
} }
} }
if(!targetfixed&&item.classList.contains('selectable')&&_status.dragstatuschanged!=item){ if(!targetfixed&&item.classList.contains('selectable')&&_status.dragstatuschanged!=item){
_status.mouseleft=true; if(items) _status.mouseleft=true;
_status.dragstatuschanged=item; _status.dragstatuschanged=item;
_status.clicked=false; _status.clicked=false;
var notbefore=itemtype=='player'&&!item.classList.contains('selected'); var notbefore=itemtype=='player'&&!item.classList.contains('selected');
@ -31320,13 +31534,26 @@
} }
return; return;
} }
if(items){
iwhile++;
item=items[iwhile];
} }
_status.mouseleft=true; else{
item=item.parentNode;
}
}
if(items) _status.mouseleft=true;
_status.dragstatuschanged=null; _status.dragstatuschanged=null;
} }
else{ else{
for(var i=0;i<items.length;i++){ if(items){
var item=items[i]; iwhile=0;
item=items[0];
}
else{
item=item0;
}
while(item){
if(item==node&&!node._mouseentercreated){ if(item==node&&!node._mouseentercreated){
ui.click.mouseentercancel(); ui.click.mouseentercancel();
var hoveration; var hoveration;
@ -31362,6 +31589,13 @@
},hoveration); },hoveration);
break; break;
} }
if(items){
iwhile++;
item=items[iwhile];
}
else{
item=item.parentNode;
}
} }
if(_status.draggingdialog){ if(_status.draggingdialog){
var ddialog=_status.draggingdialog; var ddialog=_status.draggingdialog;
@ -31392,9 +31626,22 @@
for(var i=0;i<dialogs.length;i++){ for(var i=0;i<dialogs.length;i++){
dialogs[i].delete(); dialogs[i].delete();
} }
var items=document.elementsFromPoint(e.clientX,e.clientY); var items,item,iwhile,item0;
for(var i=0;i<items.length;i++){ if(document.elementsFromPoint){
var item=items[i]; items=document.elementsFromPoint(e.clientX,e.clientY);
}
else{
item=document.elementFromPoint(e.clientX,e.clientY);
item0=item;
}
if(items){
iwhile=0;
item=items[0];
}
else{
item=item0;
}
while(item){
var itemtype=get.itemtype(item); var itemtype=get.itemtype(item);
if(itemtype=='button') break; if(itemtype=='button') break;
if(itemtype=='dialog'&& if(itemtype=='dialog'&&
@ -31416,6 +31663,13 @@
} }
return; return;
} }
if(items){
iwhile++;
item=items[iwhile];
}
else{
item=item.parentNode;
}
} }
var evt=_status.event; var evt=_status.event;
@ -31423,8 +31677,14 @@
if(!ui.arena.classList.contains('selecting')) return; if(!ui.arena.classList.contains('selecting')) return;
if(!evt.isMine()) return; if(!evt.isMine()) return;
for(var i=0;i<items.length;i++){ if(items){
var item=items[i]; iwhile=0;
item=items[0];
}
else{
item=item0;
}
while(item){
var itemtype=get.itemtype(item); var itemtype=get.itemtype(item);
if(itemtype=='card'||itemtype=='button'||itemtype=='player'){ if(itemtype=='card'||itemtype=='button'||itemtype=='player'){
if(item.classList.contains('selectable')&& if(item.classList.contains('selectable')&&
@ -31438,10 +31698,18 @@
_status.mouseleft=false; _status.mouseleft=false;
_status.selectionfull=false; _status.selectionfull=false;
_status.multitarget=false; _status.multitarget=false;
_status.lastmouseutc=get.utc();
} }
} }
return; return;
} }
if(items){
iwhile++;
item=items[iwhile];
}
else{
item=item.parentNode;
}
} }
}, },
cardtouchstart:function(e){ cardtouchstart:function(e){
@ -31527,7 +31795,7 @@
else{ else{
var tmpflag=false; var tmpflag=false;
_status.mousedown=false; _status.mousedown=false;
if(_status.mousedragging&&_status.mouseleft){ if(_status.mousedragging&&(_status.mouseleft||!document.elementsFromPoint)){
if(game.check()){ if(game.check()){
if(ui.confirm){ if(ui.confirm){
ui.confirm.close(); ui.confirm.close();