亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

jQuery制作拼圖小游戲

2024-05-06 16:14:12
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了jQuery制作拼圖小游戲,思路與源碼都分享給大家,需要的朋友可以參考下
 

源代碼思路分析:

【一】如何生成圖片網格,我想到兩種方法:

  ?。?)把這張大圖切成16張小圖,然后用img標簽的src

  ?。?)只有一張大圖,然后每個元素的背景圖用css的background-position進行切割定位,這樣就需要16個數組[0,0],[-150,0],[-300,0]..........(我采用這種)

【二】圖片背景定位數組與布局定位數組

  在選擇了使用CSS定位切圖,就需要生成數據。

     需要的css背景 定位數組為:[0,0],[-150,0],[-300,0],[-450,0],

                [0,-150],[-150,-150],[-300,-150],[-450,-150],

                [0,-300],[-150,-300],[-300,-300],[-450,-300],

                [0,-450],[-150,-450],[-300,-450],[-450,-450]

     它們當中都用到了[0,-150,-300,-450]其中的值(就是我定義圖片高,寬150的倍數值),所以就利用這個值通過for(){}自動生成數組

 

復制代碼代碼如下:

      //this.nCol在這里是4 --- 因為我的拼圖是4*4
         // this.nArea是150,是每張圖片的寬,高(600px/4)--大圖是600*600
            var l = [],
                p = [];
            for(var n=0;n<this.nCol;n++){
                l.push(n*(this.nArea+1));     //生成[0,151,302,453] 網格的布局定位數組,因為我的效果需要邊框(圖中的綠色邊框),所以與css背景定位數組就不一樣了
                p.push(-n*this.nArea);         // 生成了[0,-150,-300,-450]就是上面說的,CSS背景定位值
            }
            for(var i=0;i<this.nLen;i++){   // this.nLen 是為 16   
                var t = parseInt(i/this.nCol),
                        k = i - this.nCol*t,
                        aP = [],
                        aL = [];
                    aP.push(p[k],p[t],i); //這里我給css背景定位數組額外加了i,是為第3步判斷用的,不需要拿來設置css屬性的,我把它設置為標簽的屬性里[bg-i]
                    aL.push(l[k],l[t]);
                    this.aBgp[i] = aP;
                    this.aLayout[i] = aL;                
            }

 

【三】判斷是否完成

        第二個元素(div)應用了css背景定位  this.aBgp[1] (值為[-150,0,1]) ,而隨機分配的布局定位假如是this.aLayout[3] (這里的3是隨機生成的)(值為[453,0]),那么left:453px,top:0;

       挪動這個元素,改變的是它的letf,top值,而不是本身結構的順序,獲取這個元素的left,top的值(假如是挪到left:151px,top:0),然后拿來與this.aLayout[1]的值[151,0](里面的1索引,就是本身標簽屬性的[bg-i]=1也是this.aBgp[1] 的索引)判斷,相等就說明這個元素挪動后的位置是正確。

詳細代碼:

 

復制代碼代碼如下:

/*
    version:2.0
    */
    function GyPuzzleGame(option){
        this.target = $(option.target);
        this.data = option.data; //圖片數據
        this.opt = option;
        this.nLen = option.count; //多少張拼圖
        this.aColLayout = option.aColLayout || [0,151,302,453];//布局橫向數組
        this.aRowLayout = option.aRowLayout || [0,151];//布局豎向數組
        this.aColBgp = option.aColBgp || [0,-150,-300,-450];//布局橫向數組
        this.aRowBgp = option.aRowBgp || [0,-150];//布局豎向數組
        this.nCol = this.aColLayout.length; 
        this.nRow = this.aRowLayout.length;
        this.aLayout = []; //布局數組
        this.aBgp = []; //css背景定位數組
        this.init();
    }
    GyPuzzleGame.prototype = {
        getRand:function(a,r){
            var arry = a.slice(0),
                newArry = [];
            for(var n=0;n<r;n++){
                var nR = parseInt(Math.random()*arry.length);
                newArry.push(arry[nR]);
                arry.splice(nR,1);
            }
            return newArry;
        },
        setPos:function(){
            for(var i=0;i<this.nLen;i++){                
                var t = parseInt(i/this.nCol),
                    l = i - this.nCol*t,
                    aP = [],
                    aL = [];
                aP.push(this.aColBgp[l],this.aRowBgp[t],i);
                aL.push(this.aColLayout[l],this.aRowLayout[t]);
                this.aBgp[i] = aP;
                this.aLayout[i] = aL;                
            }
        },
        isPass:function(item){
            var _that = this,
                is = 0;
            item.each(function(){
                var l = parseInt($(this).css('left')),
                    t = parseInt($(this).css('top')),
                    i = parseInt($(this).attr('data-bgi'));
                if(l==_that.aLayout[i][0]&&t==_that.aLayout[i][1]){
                    is ++;    
                }                
            });
            return is;
        },
        createDom:function(){
            var layout = this.getRand(this.aLayout,this.nLen);
            // console.log(layout);
            for(var n=0;n<this.nLen;n++){
                var t = parseInt(n/this.nCol),
                    l = n - this.nCol*t;
                var html = $('<div data-bgi="'+this.aBgp[n][2]+'" class="puzzle_list"></div>').
                css({'left':layout[n][0]+'px',
                    'top':layout[n][1]+'px',
                    'background-image':'url('+this.data+')',
                    'background-position':this.aBgp[n][0]+'px'+' '+this.aBgp[n][1]+'px'
                });
                this.target.append(html);
            }
        },
        move:function(){
            var $div = this.target.find('.puzzle_list'),
                _that = this;
            var    hasElem = function(){
                    var t = false;
                    $div.each(function(){
                        if($(this).hasClass("on")){
                            t = true;
                        }
                    });
                    return t;
                };
            // click
            $div.click(function(){
                var $this = $(this);    
                if(hasElem()&&!$this.hasClass("on")){
                    var index = $('.on').index();
                    if($div.eq(index).is(':animated')||$this.is(':animated')){
                        return false;
                    }
                    var l = $div.eq(index).position().left,
                        t = $div.eq(index).position().top,
                        myl = $this.position().left,
                        myt = $this.position().top;
                    $(this).animate({'left':l,'top':t});
                    $div.eq(index).css({'z-index':'1'}).animate({'left':myl,'top':myt},function(){
                            $(this).removeClass("on");
                            $(this).find('span').remove();
                            $(this).css({'z-index':'0'});
                            if(_that.isPass($div) == _that.nLen){
                                if(typeof _that.opt.success == 'function'){
                                    _that.opt.success({target:_that.target});
                                }
                            }
                    });
                }
                else {
                    if($this.hasClass("on")){
                        $this.removeClass("on");
                        $this.find('span').remove();
                    }
                    else {
                        $this.addClass("on").append("<span></span>");
                    }
                }
            });
        },
        init:function(){
            // 設置CSS背景定位與元素布局數組
            this.setPos();
            // 創建元素
            this.createDom();
            // 挪動圖片
            this.move();
        }
    }
//實例調用
    new GyPuzzleGame({
        'data':'images/03.jpg',
        'target':'#pA',
        'count':8,
        'success':function(opt){
            opt.target.append('<div class="puzzle_mask"></div><div class="puzzle_pass">恭喜過關</div>');
        }
    });
 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色阁综合伊人av| 欧美香蕉大胸在线视频观看| 久久天天躁狠狠躁夜夜躁| 97视频在线观看亚洲| 国产拍精品一二三| 777午夜精品福利在线观看| 91麻豆国产语对白在线观看| 中文字幕久热精品在线视频| 日韩av中文在线| 日韩av电影在线免费播放| 欧美激情欧美激情| 91中文字幕在线| 在线日韩第一页| 国产精品人成电影在线观看| 亚洲一区二区三| 亚洲欧美日韩直播| 色综合久久88| 欧美在线观看一区二区三区| 欧美日韩国产影院| 亚洲一区二区三| 亚洲欧美日韩一区二区三区在线| 亚洲成人久久久久| 久久久中文字幕| 欧美精品videosex极品1| 日韩高清免费观看| 欧美日韩国内自拍| 2020国产精品视频| 欧美综合国产精品久久丁香| 韩国三级日本三级少妇99| 成人午夜在线视频一区| 久久躁狠狠躁夜夜爽| 欧美老女人性生活| 91情侣偷在线精品国产| 成人激情视频在线| 精品色蜜蜜精品视频在线观看| 18一19gay欧美视频网站| 色久欧美在线视频观看| 精品国产一区二区三区久久狼5月| 中文字幕精品网| 97精品国产97久久久久久| 国产精品久久久久久久久久东京| 91av视频导航| 日韩精品视频在线观看免费| 欧美亚洲国产成人精品| 狠狠色狠狠色综合日日小说| 日韩在线观看网址| 亚洲福利精品在线| 一个人看的www欧美| 色综合久综合久久综合久鬼88| 国产色视频一区| 久久精品视频亚洲| 精品久久久久国产| 福利一区视频在线观看| 国产情人节一区| 中文字幕日韩欧美精品在线观看| 欧美性受xxxx黑人猛交| 欧美电影在线免费观看网站| 欧美亚洲国产视频| 国产精品黄视频| 亚洲已满18点击进入在线看片| 日韩成人激情视频| 国产有码一区二区| 成人h视频在线观看播放| 国产福利精品av综合导导航| 免费成人高清视频| 国产精品扒开腿做| 国产精品视频精品视频| 国外成人在线直播| 欧美精品日韩三级| 久久精品国产久精国产一老狼| 欧美激情在线狂野欧美精品| 久久久日本电影| 国产成人一区二区三区| 亚洲网站在线播放| 亚洲a一级视频| 日本午夜精品理论片a级appf发布| 国产最新精品视频| 亚洲成人1234| 国产z一区二区三区| 91精品综合久久久久久五月天| 68精品久久久久久欧美| 国产精品极品美女粉嫩高清在线| 精品久久久久人成| 亚洲人成电影网站色…| 欧美日韩裸体免费视频| 亚洲电影免费观看高清| 福利视频一区二区| 这里只有精品在线播放| 国产日韩欧美日韩| 2019中文字幕在线| 国产精品久久久久久久久久久新郎| 精品国偷自产在线视频99| 国产精品视频免费观看www| 欧洲成人在线观看| 久久久久亚洲精品| 久久久久久久久91| 国产日韩精品一区二区| www国产亚洲精品久久网站| 国产精品第七影院| 91九色国产社区在线观看| 国产日韩在线精品av| 国产97在线亚洲| 欧美日韩人人澡狠狠躁视频| 国产欧美精品一区二区三区-老狼| 亚洲男人天堂九九视频| 97在线免费视频| 这里只有精品丝袜| 成人精品一区二区三区电影免费| 久久黄色av网站| 怡红院精品视频| 欧美激情视频一区二区| 久久色免费在线视频| 亚洲国产福利在线| 欧美做受高潮1| 亚洲精品一区中文字幕乱码| 国产一区二区视频在线观看| 久久视频在线播放| 91高清免费视频| 欧美亚洲在线视频| 欧美午夜www高清视频| 国产精品一区二区三区成人| 第一福利永久视频精品| 久久露脸国产精品| 日韩欧美中文字幕在线观看| 夜夜嗨av一区二区三区四区| 亚洲精品美女在线| 日韩av在线播放资源| 91tv亚洲精品香蕉国产一区7ujn| 亚洲一区中文字幕| 91精品国产99久久久久久| 日韩av电影手机在线| 国产精品日日做人人爱| 国产中文日韩欧美| 欧美成人免费全部观看天天性色| 久久躁日日躁aaaaxxxx| 亚洲精品v天堂中文字幕| 国产91九色视频| 91久久久久久久久久| 成人美女免费网站视频| 国产精品久久中文| 亚洲国产欧美一区二区三区同亚洲| 亚洲精品456在线播放狼人| 日韩av男人的天堂| 97久久精品人搡人人玩| 91精品国产91久久久久久| 国产精品免费福利| 爱福利视频一区| 亚洲精品日韩激情在线电影| 国产视频丨精品|在线观看| 97欧美精品一区二区三区| 成人日韩av在线| 久久香蕉国产线看观看网| 国产精品欧美日韩一区二区| 91tv亚洲精品香蕉国产一区7ujn| 国产精品欧美激情| 最新日韩中文字幕| 色香阁99久久精品久久久| 久久久久国色av免费观看性色| 中文字幕欧美日韩在线| 91精品啪在线观看麻豆免费| 亚洲香蕉成人av网站在线观看| 久久天天躁夜夜躁狠狠躁2022| 成人网中文字幕| 欧美另类交人妖|