html5 gqsfgw cn,spider.html

蜘蛛纸牌

* {margin: 0; padding: 0;}

html{

width: 100%;

height: 100%;

overflow: hidden;

font-size: 16px;

}

@media only screen and (max-width: 800px) {

html {

font-size: 8px;

}

}

@media only screen and (min-width: 800px) and (max-width: 950px) {

html {

font-size: 12px;

}

}

@media only screen and (min-width: 950px) and (max-width: 1100px){

html {

font-size: 14px;

}

}

body {

width: 100%;

height: 100%;

overflow: hidden;

font-size: 0;

background: #228B22;

}

.footer{

position: absolute;

width: 100%;

height: 2rem;

left: 0;

bottom: 1rem;

text-align: left;

}

.footer .toolbar, .footer .info{

display: inline-block;

width: 50%;

height: 100%;

}

.footer .info{

font-size: 1rem;

line-height: 2rem;

vertical-align: text-bottom;

}

.footer .info em{

margin-right: 1rem;

font-style: normal;

}

.footer .toolbar button{

display:inline-block;

vertical-align: text-bottom;

width: 0;

height: 0;

border: none;

background: none;

font-size: 0;

border-left: 2rem solid red;

border-top: 1rem solid transparent;

border-bottom: 1rem solid transparent;

outline: none; /* 解决按钮点击后出现蓝色边框的问题 */

}

.footer .toolbar span{

font-size: 1rem;

line-height: 2rem;

margin-left: 1rem;

vertical-align: text-bottom;

}

.complete-area{

position: absolute;

left: 1rem;

bottom: 3rem;

height: 8.1rem;

width: 20.2rem;

}

.deal-area{

position: absolute;

right: 1rem;

bottom: 3rem;

height: 8.1rem;

width: 8.2rem;

}

.play-area{

margin: 2rem auto 0;

text-align: center;

width: 66rem;

}

.place{

width: 6rem;

height: 8rem;

margin: 0 0.3rem;

display: inline-block;

position: relative;

background-color: #32CD32;

border-radius: 0.5rem;

}

/* 黑桃,梅花 */

.spades,.clubs{

color: black;

}

/* 红桃,方片 */

.hearts,.diams{

color: #DC143C; /* crimson */

}

.play-area .card{

left: 0;

}

.card{

position: absolute;

top: 0;

z-index: 0;

display: inline-block;

width: 6rem;

height: 8rem;

border: 0.05rem solid #888;

border-radius: 0.5rem;

background-color: white;

font-family: sans-serif,serif;

cursor: move;

}

.card:after{

content: "";

width: 100%;

height: 100%;

position: absolute;

left: 0;

top: 0;

}

.card > *{

position: absolute;

display: inline-block;

}

.card.back{

cursor: default;

}

.card.back:after{

content: "";

background-color: #87CEEB;

border-radius: 0.25rem;

width: 5.5rem;

height: 7.5rem;

position: absolute;

left: 0.25rem;

top: 0.25rem;

}

.card img {

width: 1.5rem;

height: 1.5rem;

}

.card .num {

width: 1.2rem;

height: 2rem;

text-align: center;

}

.card .shape{

width: 3.6rem;

height: 100%;

left: 1.2rem;

top: 0;

}

.card .num > div{

font-size: 1rem;

line-height: 1rem;

font-weight: bold;

}

.card.back .num > div{

font-size: 0;

}

.card .num img{

width: 1rem;

height: 1rem;

}

.card.back .num img{

width: 0;

}

/* lt: left top*/

.card .num.lt{

top: 0.2rem;

left: 0;

}

/* rb: right bottom*/

.card .num.rb{

bottom: 0.2rem;

right: 0;

}

.shape .one{

width: 100%;

height: 100%;

}

.shape .one img{

width: 2rem;

height: 2rem;

margin-top: 3rem;

}

.shape .one-third{

width: 100%;

height: 33%; /* 2.6rem */

font-size: 0;

}

.shape .one-third img{

margin-top: 0.55rem;

}

.shape .half-width{

display: inline-block;

width: 50%;

height: 100%;

text-align: right;

}

.shape .half-width:first-child{

text-align: left;

}

.shape .one-third-up,.shape .one-third-down{

width: 100%;

height: 5.2rem;

position: absolute;

}

.shape .one-third-up img,.shape .one-third-down img{

margin-top: 1.85rem;

}

.shape .one-third-up{

top: 0;

left: 0;

}

.shape .one-third-down{

bottom: 0;

left: 0;

}

.shape .one-quarter{

width: 100%;

height: 25%; /* 2rem*/

}

.shape .one-quarter img{

margin-top: 0.25rem;

}

.shape .nine{

width: 100%;

height: 100%;

position: absolute;

top: 0;

left: 0;

}

.shape .nine img{

margin-top: 3.25rem;

}

.shape .ten-up,.shape .ten-down{

width: 100%;

height: 50%; /*4rem*/

position: absolute;

}

.shape .ten-up img,.shape .ten-down img{

margin-top: 1.25rem;

}

.shape .ten-up{

top: 0;

}

.shape .ten-down{

bottom: 0;

}

.shape .jqk{

width: 100%;

height: 7rem;

border: 0.05rem solid;

border-radius: 0.5rem;

margin: 0.45rem 0;

}

.shape .jqk-tl,.shape .jqk-tr,.shape .jqk-bl,.shape .jqk-br{

width: 50%;

height: 3.5rem;

position: absolute;

}

.shape .jqk-tr,.shape .jqk-bl{

line-height: 3.5rem;

font-size: 2rem;

}

.shape .jqk-tl img,.shape .jqk-br img{

margin-top: 1rem;

}

.shape .jqk-tl{

top: 0.5rem;

left: 0;

}

.shape .jqk-tr{

top: 0.5rem;

right: 0;

}

.shape .jqk-bl{

bottom: 0.5rem;

left: 0;

}

.shape .jqk-br{

bottom: 0.5rem;

right: 0;

}

.mirror-rotate-vertical{ /* 垂直镜像翻转 */

-moz-transform:scaleY(-1);

-webkit-transform:scaleY(-1);

-o-transform:scaleY(-1);

transform:scaleY(-1);

/*兼容IE*/

filter:FlipV;

}

.mirror-rotate-level { /* 水平镜像翻转 */

-moz-transform:scaleX(-1);

-webkit-transform:scaleX(-1);

-o-transform:scaleX(-1);

transform:scaleX(-1);

/*兼容IE*/

filter:FlipH;

}

/* 禁止选中 */

.no-select {

moz-user-select: -moz-none;

-moz-user-select: none;

-o-user-select: none;

-khtml-user-select: none;

-webkit-user-select: none;

-ms-user-select: none;

user-select: none;

}

.alert,.confirm{

position: absolute;

z-index: 2;

width: 100%;

height: 100%;

top: 0;

left: 0;

background-color: rgba(255,255,255,0.3);

display: none;

}

.alert-content,.confirm-content{

top: 35%;

left: 30%;

height: 30%;

width: 40%;

position: absolute;

font-size: 2rem;

font-weight: bolder;

text-align: center;

border-radius: 0.5rem;

}

.confirm-content{

background-color: #F0F8FF;

}

.confirm-content > div{

margin-top: 1rem;

}

.confirm button{

padding: 0.5rem;

}

你赢了!

再玩一局

  退  出  

无路可走了

返回再试一次

再玩一局

  退  出  

let test;

window.onload = function(){

SpiderSolitaire.init();

};

// 扑克牌类

class Card{

// num 牌面数(String类型),digit 牌面数(数字),suit 花色,deck 第几副牌

constructor(num,digit,suit,deck) {

this.num = num;

this.digit = digit;

this.suit = suit;

this.deck = deck;

}

}

// 蜘蛛纸牌

let SpiderSolitaire = {

oneRemToPx: 0,

cardWidth: 0,

cardHeight: 0,

defaultCardSpace: 1.5, /* 牌间距 */

cardSpaceList: [], /* 牌间距 */

movable: false,

moveObj: null,

movingCardList: [],

places: [],

placeShownCards: [],

notDealedCards: [],// 待发的牌

preX: 0,

preY: 0,

cardTopList: [],

cardLeftList: [],

steps: 0, /* 移动步数 */

init(){

this.oneRemToPx = document.getElementById("place0").clientWidth / 6.0;

this.cardWidth = this.oneRemToPx * 6.1;

this.cardHeight = this.oneRemToPx * 8.1;

// 放牌列

for(let i = 0; i<10; i++){

this.places[i] = document.getElementById("place" + i.toString());

this.cardSpaceList[i] = this.defaultCardSpace;

}

// 初始化玩牌区

SpiderSolitaire.initPlayArea();

// 初始化发牌区

SpiderSolitaire.initDealArea();

// 为document注册事件

SpiderSolitaire.bindDocumentMoveEvent();

if(SpiderSolitaire.isMobile()){

// 按钮阻止touchstart

let buttons = document.getElementsByTagName("button");

for(let btn of buttons){

btn.addEventListener("touchstart",SpiderSolitaire.stopPropagation);

}

}

},

replay(confirmId){

if(confirmId){

// 关闭confirm

SpiderSolitaire.closeConfirm(confirmId);

}

// 初始化玩牌区

SpiderSolitaire.initPlayArea();

// 初始化发牌区

SpiderSolitaire.initDealArea();

// 清空完成区

document.getElementById("completeArea").innerHTML = "";

// 重置步数

SpiderSolitaire.steps = -1;

SpiderSolitaire.addStep();

},

exit(){

// 关闭当前窗口

window.opener=null;

let w = window.open("about:blank", "_self");

window.close();

},

initPlayArea(){

this.notDealedCards = this.createDeckCard(2);

// 放牌位置

for(let i = 0; i<10; i++){

this.places[i].innerHTML = "";

this.placeShownCards[i] = [];

let j = 0;

for(j=0; j < 4; j++ ){

this.placeCardElement(this.getRandomCard(),null,this.places[i],this.getCardBackElement,j);

}

if(i < 4){

this.placeCardElement(this.getRandomCard(),null,this.places[i],this.getCardBackElement,j);

j++;

}

this.placeCardElement(this.getRandomCard(),this.placeShownCards[i],this.places[i],this.getCardElement,j);

}

},

placeCardElement(card,placeShownCards,place,getCardElementFun,index){

if(placeShownCards){

placeShownCards.push(card);

}

let cardElementObj = getCardElementFun(card);

this.initPlayAreaCardElement(cardElementObj,(index/2.0)+"rem");

// 把牌放入列

place.appendChild(cardElementObj);

},

getRandomCard(){

let cardIndex = Math.floor(Math.random()*(this.notDealedCards.length));

let result = this.notDealedCards[cardIndex];

// 删除已发的牌

this.notDealedCards.splice(cardIndex,1);

return result;

},

initDealArea(){

let dealArea = document.getElementById("dealArea");

dealArea.innerHTML = "";

let right = "0rem";

let card = null;

let cardElementObj;

for(let i = 0; i < 5; i++){

right = String(i/2.0)+ "rem";

for(let j=0; j < 10; j++){

card = this.getRandomCard();

cardElementObj = this.getCardBackElement(card);

dealArea.appendChild(cardElementObj);

this.initDealAreaCardElement(cardElementObj,right);

if(j == 9){

cardElementObj.addEventListener("click",SpiderSolitaire.dealCards);

if(SpiderSolitaire.isMobile()){

cardElementObj.addEventListener("touchstart",SpiderSolitaire.stopPropagation);

}

}

}

}

},

/** 创建牌: deckNum 几副牌 */

createDeckCard(deckNum){

let cards = [];

let numMap = ['A','2','3','4','5','6','7','8','9','10','J','Q','K'];

let suitMap = ["spades","hearts","clubs","diams"];

for(let i = 0; i < deckNum; i++){

for(let j = 0; j < 13; j++){

for(let k = 0; k < 4; k++){

cards.push(new Card(numMap[j], j+1 ,suitMap[k],i));

}

}

}

return cards;

},

initPlayAreaCardElement(cardElementObj,top){

cardElementObj.style.top = top;

if(!cardElementObj.classList.contains("back")){

SpiderSolitaire.bindCardMoveEvent(cardElementObj);

}

},

initDealAreaCardElement(cardElementObj,right){

cardElementObj.style.right = right;

},

/** 模版替换 */

templateReplace(template,data){

return template.replace(/\$\{(\w+)\}/g, function(match,key){

return typeof(data[key]) == "undefined" ? "" : data[key];

});

},

getCardTemplate(num,suit){

// 黑桃、红桃、梅花、方片图片的base64编码

let suitImgs = {};

suitImgs.spades = "";

suitImgs.hearts = "";

suitImgs.clubs = "";

suitImgs.diams = "";

let data = {"num": num, "suit": suit, "suitImg": suitImgs[suit]};

let templateNum = num.toUpperCase();

if("JQK".indexOf(templateNum) != -1){

templateNum = "JQK";

}

let numTemplate = document.getElementById("numTemplate" + templateNum).innerHTML;

data["shape"] = SpiderSolitaire.templateReplace(numTemplate,data);

let cardTemplate = document.getElementById("cardTemplate").innerHTML;

return SpiderSolitaire.templateReplace(cardTemplate,data);

},

getCardElement(card){

let cardTransfrom = document.createElement("div");

cardTransfrom.innerHTML = SpiderSolitaire.getCardTemplate(card.num, card.suit);

cardTransfrom.lastElementChild.card = card;

return cardTransfrom.lastElementChild;

},

getCardBackElement(card){

let cardElementObj = SpiderSolitaire.getCardElement(card);

cardElementObj.classList.add("back");

return cardElementObj;

},

transformBack(cardElementObj){

cardElementObj.classList.add("back");

return cardElementObj;

},

transformFront(cardElementObj){

cardElementObj.classList.remove("back");

SpiderSolitaire.bindCardMoveEvent(cardElementObj);

let index = SpiderSolitaire.places.indexOf(cardElementObj.parentElement);

SpiderSolitaire.placeShownCards[index].push(cardElementObj.card);

return cardElementObj;

},

bindCardMoveEvent(cartElementObj){

if(SpiderSolitaire.isMobile()){ // 移动端

cartElementObj.addEventListener("touchstart",SpiderSolitaire.touchStart);

}else{ // PC端

cartElementObj.addEventListener("mousedown",SpiderSolitaire.mouseDown);

}

},

unbindCardMoveEvent(cartElementObj){

if(SpiderSolitaire.isMobile()){ // 移动端

cartElementObj.removeEventListener("touchstart",SpiderSolitaire.touchStart);

}else{ // PC端

cartElementObj.removeEventListener("mousedown",SpiderSolitaire.mouseDown);

}

},

bindDocumentMoveEvent(){

if(SpiderSolitaire.isMobile()){ // 移动端

// 禁止选中

document.body.addEventListener('touchstart', function (e) {

e.preventDefault();

}, {passive: false});

// 阻止页面滑动

document.body.addEventListener('touchmove', function (e) {

e.preventDefault();

}, {passive: false});

//防止页面后退

history.pushState(null, null, document.URL);

window.addEventListener('popstate', function () {

history.pushState(null, null, document.URL);

});

document.addEventListener("touchmove",SpiderSolitaire.touchMove);

document.addEventListener("touchend",SpiderSolitaire.touchEnd);

}else{ // PC端

document.addEventListener("mousemove",SpiderSolitaire.mouseMove);

document.addEventListener("mouseup",SpiderSolitaire.mouseUp);

}

},

isMobile(){

// 判断是否在移动端打开

return /Android|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent);

},

stopPropagation(e){

e.stopPropagation();

},

mouseDown(e){

SpiderSolitaire.moveStart(e.clientX, e.clientY, this);

},

mouseMove(e){

SpiderSolitaire.move(e.clientX, e.clientY);

},

mouseUp(e){

SpiderSolitaire.moveEnd(e.clientX, e.clientY);

},

touchStart(e){

let x = e.touches[0].clientX;

let y = e.touches[0].clientY;

SpiderSolitaire.moveStart(x, y, this);

},

touchMove(e){

let x = e.touches[0].clientX;

let y = e.touches[0].clientY;

SpiderSolitaire.move(x, y);

},

touchEnd(e){

let x = e.changedTouches[0].clientX;

let y = e.changedTouches[0].clientY;

SpiderSolitaire.moveEnd(x, y);

},

moveStart(clientX,clientY,mObj){

SpiderSolitaire.movable = true;

// 清空数组

SpiderSolitaire.clearCardList();

SpiderSolitaire.moveObj = mObj;

SpiderSolitaire.movingCardList.push(mObj);

SpiderSolitaire.cardTopList.push(mObj.offsetTop);

SpiderSolitaire.cardLeftList.push(mObj.offsetLeft);

SpiderSolitaire.moveObj.style.zIndex = 1;

while(mObj.nextElementSibling){

if((mObj.card.digit != mObj.nextElementSibling.card.digit + 1)

|| (mObj.card.suit != mObj.nextElementSibling.card.suit)){

SpiderSolitaire.movable = false;

for(let mc of SpiderSolitaire.movingCardList){

mc.style.zIndex = 0;

}

break;

}

mObj = mObj.nextElementSibling;

SpiderSolitaire.movingCardList.push(mObj);

SpiderSolitaire.cardTopList.push(mObj.offsetTop);

SpiderSolitaire.cardLeftList.push(mObj.offsetLeft);

mObj.style.zIndex = 1;

}

SpiderSolitaire.preX = clientX;

SpiderSolitaire.preY = clientY;

},

move(clientX,clientY){

if(SpiderSolitaire.movable){

for(let c of SpiderSolitaire.movingCardList){

c.style.left = (c.offsetLeft + clientX - SpiderSolitaire.preX) + "px";

c.style.top = (c.offsetTop + clientY - SpiderSolitaire.preY) + "px";

}

SpiderSolitaire.preX = clientX;

SpiderSolitaire.preY = clientY;

}

},

moveEnd(clientX, clientY){

if(SpiderSolitaire.moveObj && SpiderSolitaire.movable){

SpiderSolitaire.movable = false;

let originalPlace = true;// 是否放回原位

let hasLastChild = true; // 是否有子元素

let lastChildoffsetTop = 0; // 最后一个子元素的offsetTop

let originalPlaceIndex = SpiderSolitaire.places.indexOf(SpiderSolitaire.moveObj.parentElement);

for(let i = 0; i < 10; i++){

if(originalPlaceIndex == i){

continue;

}

if(SpiderSolitaire.places[i].lastElementChild){

hasLastChild = true;

lastChildoffsetTop = SpiderSolitaire.places[i].lastElementChild.offsetTop;

}else{

hasLastChild = false;

lastChildoffsetTop = 0;

}

// 判断是否移到了新列

if(SpiderSolitaire.isInNewPlace(i, clientX, clientY, lastChildoffsetTop)){

// 判断是否可以放到新列

if(!hasLastChild || (SpiderSolitaire.places[i].lastElementChild.card.digit == SpiderSolitaire.moveObj.card.digit + 1)){

// 移到新位置

SpiderSolitaire.moveToNewPlace(i,hasLastChild,lastChildoffsetTop);

// 判断一列是否完成

let complete = SpiderSolitaire.isComplete(i);

let win = false;

// 判断是否已经获胜

if(complete){

win = SpiderSolitaire.isWin();

}

if(!complete || !win){

// 没有赢

SpiderSolitaire.adjustHeight();

// 判断是否有路可走

SpiderSolitaire.hasWay();

}

// 增加移牌步数

SpiderSolitaire.addStep();

originalPlace = false;

}

break;

}

}

for(let k = 0; k < SpiderSolitaire.movingCardList.length; k++){

SpiderSolitaire.movingCardList[k].style.zIndex = 0;

if(originalPlace){// 是否放回原位

SpiderSolitaire.movingCardList[k].style.top = SpiderSolitaire.cardTopList[k] + "px";

SpiderSolitaire.movingCardList[k].style.left = SpiderSolitaire.cardLeftList[k] + "px";

}

}

SpiderSolitaire.moveObj = null;

// 清空数组

SpiderSolitaire.clearCardList();

}

},

clearCardList(){

// 清空card相关数组

SpiderSolitaire.movingCardList.splice(0,SpiderSolitaire.movingCardList.length);

SpiderSolitaire.cardTopList.splice(0,SpiderSolitaire.cardTopList.length);

SpiderSolitaire.cardLeftList.splice(0,SpiderSolitaire.cardLeftList.length);

},

isInNewPlace(newPlaceIndex, x, y,newPlaceOffsetTop){

let t = SpiderSolitaire.places[newPlaceIndex].offsetTop + newPlaceOffsetTop;

let b = t + SpiderSolitaire.cardHeight * 1.75;

let l = SpiderSolitaire.places[newPlaceIndex].offsetLeft;

let r = l + SpiderSolitaire.cardWidth;

return (x >= l && x <= r && y >= t && y <= b);

},

moveToNewPlace(newPlaceIndex,newPlaceHasChild,newPlaceOffsetTop){

let moveObjParentElement = SpiderSolitaire.moveObj.parentElement;

// 从原placeCards移到新placeCards

SpiderSolitaire.moveToNewPlaceShownCards(newPlaceIndex);

let newPlace = SpiderSolitaire.places[newPlaceIndex];

for(let j = 0; j < SpiderSolitaire.movingCardList.length; j++){

// 加入新列(同时会从原列移除)

newPlace.appendChild(SpiderSolitaire.movingCardList[j]);

// 设置牌在新列位置

if(newPlaceHasChild){

newPlace.lastElementChild.style.top =

(newPlaceOffsetTop + (SpiderSolitaire.oneRemToPx * SpiderSolitaire.cardSpaceList[newPlaceIndex])*(j+1)) + "px";

}else{

newPlace.lastElementChild.style.top = (SpiderSolitaire.oneRemToPx * SpiderSolitaire.cardSpaceList[newPlaceIndex] * j) + "px";

}

SpiderSolitaire.places[newPlaceIndex].lastElementChild.style.left = "0px";

//是否翻牌

if(moveObjParentElement.lastElementChild && moveObjParentElement.lastElementChild.classList.contains("back")){// 翻牌

// 把背面牌转为牌面

SpiderSolitaire.transformFront(moveObjParentElement.lastElementChild);

}

}

},

/**

* 从原placeCards移到新placeCards

*/

moveToNewPlaceShownCards(newPlaceIndex){

// 移动的牌原来所在的place元素

let moveObjParentElement = SpiderSolitaire.moveObj.parentElement;

// 移动的牌原来在第几列

let originalPlaceCardsIndex = SpiderSolitaire.places.indexOf(moveObjParentElement);

let OriginalplaceCards = SpiderSolitaire.placeShownCards[originalPlaceCardsIndex];

let movingCardsLength = SpiderSolitaire.movingCardList.length;

let movedObjList = OriginalplaceCards.splice(OriginalplaceCards.length - movingCardsLength, movingCardsLength);

SpiderSolitaire.placeShownCards[newPlaceIndex] = SpiderSolitaire.placeShownCards[newPlaceIndex].concat(movedObjList);

},

isComplete(placeIndex){

let complete = false;

let place = SpiderSolitaire.places[placeIndex];

let shownCards = SpiderSolitaire.placeShownCards[placeIndex];

if(shownCards.length >= 13){// 少于13张,不可能完成

complete = true;

let len = shownCards.length;

let suit = shownCards[len-13].suit;

for(let i = len - 13; i < len; i++){// 最后13张牌

if((shownCards[i].digit != len - i) || shownCards[i].suit != suit){

complete = false;

break;

}

}

if(complete){

let kCard = shownCards[len-13];

// 从shownCards中移除

shownCards.splice(len - 13, 13);

// 从列中移除

for(let j=0; j<13; j++){

SpiderSolitaire.places[placeIndex].removeChild(SpiderSolitaire.places[placeIndex].lastElementChild);

}

// 放K到完成区

let completeArea = document.getElementById("completeArea");

completeArea.appendChild(SpiderSolitaire.getCardElement(kCard));

if(completeArea.childElementCount > 1){

completeArea.lastElementChild.style.left = ((completeArea.childElementCount - 1) * 2 * SpiderSolitaire.oneRemToPx) + "px";

}

//是否翻牌

if(place.lastElementChild && place.lastElementChild.classList.contains("back")){// 翻牌

// 把背面牌转为牌面

SpiderSolitaire.transformFront(place.lastElementChild);

}

}

}

return complete;

},

isWin(){

for(let i = 0; i < 10; i++){

if(SpiderSolitaire.places[i].childElementCount > 0){

// 还没赢

return false;

}

}

// 获胜

SpiderSolitaire.showConfirm("winConfirm");

return true;

},

/**

* 判断是否有路可走

*/

hasWay(){

if(document.getElementById("dealArea").childElementCount > 0){

return true;

}

let cur = null, pre = null;

let start = 0, end = 0, compare = 0;

for(let i = 0; i < 10; i++){

// 如果列中有元素

if(SpiderSolitaire.places[i].childElementCount > 0){

cur = SpiderSolitaire.places[i].lastElementChild;

start = end = cur.card.digit;

while(cur.previousElementSibling){

pre = cur.previousElementSibling;

if(pre.card.digit == (cur.card.digit + 1) && pre.card.suit == cur.card.suit){

end = pre.card.digit;

cur = pre;

}else{

break;

}

}

for(let j=0; j < 10; j++){

if(i != j){

if(SpiderSolitaire.places[j].childElementCount > 0){

compare = SpiderSolitaire.places[j].lastElementChild.card.digit;

if(compare == (end + 1)){

return true;

}

}else{

return true;

}

}

}

}else{

// 列中没有元素,一定有路可走

return true;

}

}

SpiderSolitaire.showConfirm("nowayConfirm");

return false;

},

/**

* 调整列高度,防止列太长

*/

adjustHeight(){

let topT = document.getElementById("playArea").offsetTop;

let topB = document.getElementById("completeArea").offsetTop;

let backLen = 0;

let cardSpace = 0;

let backSpaceHeight = null;

let frontSpaceHeight = null;

for(let i = 0; i < 10; i++){

if(SpiderSolitaire.places[i].childElementCount > 1){

backLen = SpiderSolitaire.places[i].childElementCount - SpiderSolitaire.placeShownCards[i].length;

backSpaceHeight = backLen * 0.5 * SpiderSolitaire.oneRemToPx;

frontSpaceHeight = (SpiderSolitaire.placeShownCards[i].length - 1) * SpiderSolitaire.cardSpaceList[i] * SpiderSolitaire.oneRemToPx;

cardSpace = (topB - topT - backSpaceHeight - SpiderSolitaire.cardHeight)/(SpiderSolitaire.placeShownCards[i].length - 1);

cardSpace = cardSpace > 0 ? cardSpace : 0;

// 保留1位小数,并向下舍入

cardSpace = cardSpace / SpiderSolitaire.oneRemToPx * 10;

cardSpace = Math.floor(cardSpace) / 10;

cardSpace = cardSpace > SpiderSolitaire.defaultCardSpace ? SpiderSolitaire.defaultCardSpace : cardSpace;

if(cardSpace != SpiderSolitaire.cardSpaceList[i]){

SpiderSolitaire.cardSpaceList[i] = cardSpace;

for(let j = backLen + 1; j < SpiderSolitaire.places[i].childElementCount; j++){

SpiderSolitaire.places[i].children[j].style.top = (backSpaceHeight + (j - backLen) * SpiderSolitaire.cardSpaceList[i]*SpiderSolitaire.oneRemToPx) + "px";

}

}

}

}

},

dealCards(){

for(let j = 0; j < 10; j++){

if(SpiderSolitaire.places[j].childElementCount < 1){

SpiderSolitaire.showAlert("有空位不能发牌");

return;

}

}

let dealArea = document.getElementById("dealArea");

let top;

for(let i=0; i < 10; i++){

if(SpiderSolitaire.places[i].lastElementChild){

top = SpiderSolitaire.places[i].lastElementChild.offsetTop

+ SpiderSolitaire.cardSpaceList[i] * SpiderSolitaire.oneRemToPx;

}else{

top = 0;

}

if(i == 0){

//移除事件

dealArea.lastElementChild.removeEventListener("click", SpiderSolitaire.dealCards);

if(SpiderSolitaire.isMobile()){

dealArea.lastElementChild.removeEventListener("touchstart", SpiderSolitaire.stopPropagation);

}

}

SpiderSolitaire.places[i].appendChild(dealArea.lastElementChild);

SpiderSolitaire.transformFront(SpiderSolitaire.places[i].lastElementChild);

SpiderSolitaire.places[i].lastElementChild.style.right = "";

SpiderSolitaire.places[i].lastElementChild.style.left = "0px";

SpiderSolitaire.places[i].lastElementChild.style.top = top + "px";

// 判断列是否完成

SpiderSolitaire.isComplete(i);

}

// 调整列长

SpiderSolitaire.adjustHeight();

// 判断是否有路可走

SpiderSolitaire.hasWay();

},

addStep(){

SpiderSolitaire.steps ++ ;

document.getElementById("steps").innerHTML = SpiderSolitaire.steps;

},

showAlert(content){

let alertElementObj = document.getElementById("alert");

alertElementObj.firstElementChild.innerHTML = content;

alertElementObj.style.display = "block";

window.setTimeout(function(){alertElementObj.style.display = "none";},1000);

},

showConfirm(confirmId){

document.getElementById(confirmId).style.display = "block";

},

closeConfirm(confirmId){

document.getElementById(confirmId).style.display = "none";

},

};

${num}

%24%7BsuitImg%7D

${shape}

${num}

%24%7BsuitImg%7D

%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
%24%7BsuitImg%7D
${num}
${num}
%24%7BsuitImg%7D

一键复制

编辑

Web IDE

原始数据

按行查看

历史

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值