HTML+Javascript制作拼图小游戏详解(终)

上次我们已经讲解了制作的原理,并且展示了主要代码。

这次我将完整的代码给大家,仅供参考。

HTML部分如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>拼图游戏——初级</title>
    <link rel="stylesheet" href="css/button.css">
    <script src="js/jquery.js"></script>
    <script src="js/level1.js"></script>
</head>
<body>
<div class="main">
<div class="left">
<h3>目标图</h3>
<div class="pic" id="mainpic"></div>
<br><br>
<h3>所用时间</h3>
<p id="timer">0分0秒</p>
</div>
<div class="center">
    <table class="picbox" cellspacing="0" cellpadding="1">
    <tbody id="picbox">
    </tbody>
    </table>
</div>
<div class="right">
    <a href="javascript:startgame()" class="btn btn-sm animated-button victoria-one">开始</a>
    <a href="level1.html" class="btn btn-sm animated-button victoria-two">初级</a>
    <a href="level2.html" class="btn btn-sm animated-button victoria-three">中级</a> 
    <a href="level3.html" class="btn btn-sm animated-button victoria-four">高级</a> 
</div>
</div>
<div class="wingame">
<h2>恭喜你完成拼图!</h2>
<div class="pic pic2"></div>
<p>完成耗时:<b id="timer2">0分0秒</b></p>
</div>
</body>
</html>

 

CSS代码如下

body
{
    background-color: #E8E8E8;
}
.main
{
    margin:0 auto;
    width: 1250px;
    height: 720px;
}
.left
{
    width: 300px;
    height: 700px;
    float: left;;
}
.center
{
    width: 700px;
    height: 700px;
    float: left;
}
.right
{
    width: 250px;
    height: 700px;
    color: red;
    float: right;
    
}
.picbox
    {
        margin: 0 auto;
        border: 1px solid black;
        width: 650px;
        height: 650px;
    }
    .picbpx td
    {
        padding: 0;
    }
    .border_bg
    {
        background-image:url(../img/border_bg.jpg);
        width: 100px;
        height: 100px;
        background-repeat: repeat;
    }
    .left h3
    {
        text-align: center;;
    }
    #timer
    {
        color: #D24D57;
        text-align: center;
        font-size:23px;
        font-weight: bold;
    }
    .pic
    {
        margin: 20px auto;
        background-size: cover;
        width: 270px;
        height: 250px;
        border: 2px solid #FFF;
    }
    .wingame
    {
        display: none;
        width: 600px;
        height: 300px;
        background-color: rgba(80,100,120,0.5);
        position: fixed;
        top:25vh;
        left: 32vw;
    }
    .pic2
    {
        width: 150px;
        height: 150px;
    }
    .pic2:hover
    {
        cursor:pointer;
    }
    .wingame h2
    {
        text-align: center;
    }
    .wingame p
    {
        font-size: 20px;
        text-align: center;
    }
    .wingame p b
    {
        color: rgb(200,60,60);
    }


    /*按钮美化*/
a.animated-button:link, a.animated-button:visited {
    position: relative;
    display: block;
    margin: 30px auto 0;
    padding: 14px 15px;
    color: #fff;
    font-size:14px;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
    text-transform: uppercase;
    overflow: hidden;
    letter-spacing: .08em;
    border-radius: 0;
    text-shadow: 0 0 1px rgba(0, 0, 0, 0.2), 0 1px 0 rgba(0, 0, 0, 0.2);
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    transition: all 1s ease;
}
a.animated-button:link:after, a.animated-button:visited:after {
    content: "";
    position: absolute;
    height: 0%;
    left: 50%;
    top: 50%;
    width: 150%;
    z-index: -1;
    -webkit-transition: all 0.75s ease 0s;
    -moz-transition: all 0.75s ease 0s;
    -o-transition: all 0.75s ease 0s;
    transition: all 0.75s ease 0s;
}
a.animated-button:link:hover, a.animated-button:visited:hover {
    color: #FFF;
    text-shadow: none;
}
a.animated-button:link:hover:after, a.animated-button:visited:hover:after {
    height: 450%;
}
a.animated-button:link, a.animated-button:visited {
    position: relative;
    display: block;
    margin: 30px auto 0;
    padding: 14px 15px;
    color: #000;
    font-size:25px;
    border-radius: 0;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
    text-transform: uppercase;
    overflow: hidden;
    letter-spacing: .08em;
    text-shadow: 0 0 1px rgba(0, 0, 0, 0.2), 0 1px 0 rgba(0, 0, 0, 0.2);
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    transition: all 1s ease;
}

/* Victoria Buttons */
a
{
    width: 200px;
    height: 50px;
}
a.animated-button.victoria-one {
    border: 2px solid #D24D57;
}
a.animated-button.victoria-one:after {
    background: #D24D57;
    -moz-transform: translateX(-50%) translateY(-50%) rotate(-25deg);
    -ms-transform: translateX(-50%) translateY(-50%) rotate(-25deg);
    -webkit-transform: translateX(-50%) translateY(-50%) rotate(-25deg);
    transform: translateX(-50%) translateY(-50%) rotate(-25deg);
}
a.animated-button.victoria-two {
    border: 2px solid #D24D57;
}
a.animated-button.victoria-two:after {
    background: #D24D57;
    -moz-transform: translateX(-50%) translateY(-50%) rotate(25deg);
    -ms-transform: translateX(-50%) translateY(-50%) rotate(25deg);
    -webkit-transform: translateX(-50%) translateY(-50%) rotate(25deg);
    transform: translateX(-50%) translateY(-50%) rotate(25deg);
}
a.animated-button.victoria-three {
    border: 2px solid #D24D57;
}
a.animated-button.victoria-three:after {
    background: #D24D57;
    opacity: .5;
    -moz-transform: translateX(-50%) translateY(-50%);
    -ms-transform: translateX(-50%) translateY(-50%);
    -webkit-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
}
a.animated-button.victoria-three:hover:after {
    height: 140%;
    opacity: 1;
}
a.animated-button.victoria-four {
    border: 2px solid #D24D57;
}
a.animated-button.victoria-four:after {
    background: #D24D57;
    opacity: .5;
    -moz-transform: translateY(-50%) translateX(-50%) rotate(90deg);
    -ms-transform: translateY(-50%) translateX(-50%) rotate(90deg);
    -webkit-transform: translateY(-50%) translateX(-50%) rotate(90deg);
    transform: translateY(-50%) translateX(-50%) rotate(90deg);
}
a.animated-button.victoria-four:hover:after {
    opacity: 1;
    height: 600% !important;
}
a.animated-button.victoria-five {
    border: 2px solid red;
}
a.animated-button.victoria-five:after {
    background: #D24D57;
    -moz-transform: translateX(-50%) translateY(-50%) rotate(-25deg);
    -ms-transform: translateX(-50%) translateY(-50%) rotate(-25deg);
    -webkit-transform: translateX(-50%) translateY(-50%) rotate(-25deg);
    transform: translateX(-50%) translateY(-50%) rotate(-25deg);
}

最后式Js代码:

var picnum=5;
var picData=[];
var a_num=[];
var level="level1";
var isstart=false;
$(document).ready(function(){
    showpicmain();//显示需要拼的目标图
    for(var i=0;i<picnum;i++)//创建拼图表格的行
    {
        $('#picbox').append("<tr></tr>");
    }
    for(var i=0;i<picnum;i++)//创建拼图表格的列
    {
        $('#picbox').children().append("<td></td>");
    }
    $('#startgame').attr("onclick","startgame()");//开始按钮监听事件
    var tds=$('#picbox').children().children();//获得td的数组
    //console.log(tds.length);
    
    for(var i=0;i<tds.length;i++)//为每个td加id和点击事件
    {
        id=i+1;
        tds[i].setAttribute("id",id);
        tds[i].setAttribute("onclick","movepic("+id+")")
    }
    init();
    saveData();
    setBorder();
    setendpic();
});
function setendpic()//加入最后一张图片
{
    temp=picnum*(picnum-1)-1;
    $('#'+temp).css("background-image","url(img/"+level+"/_0"+(picnum-2)*(picnum-2)+".jpg)")
}
function iskong(id)//判断改标签是否为空
{
    
    var bg=$('#'+id).css("background-image");
    if(bg=="none"){
        return true;
    }else
    {
        return false;
    }
}
function movepic(id)//移动图片
{
    if(iskong(id-picnum))
    {
        //alert("moveup");
        move(id,id-picnum);
    }
    else if(iskong(id+picnum))
    {
        //alert("movedown");
        move(id,id+picnum);
    }
    else if(iskong(id-1))
    {
        //alert("moveleft");
        move(id,id-1);
    }
    else if(iskong(id+1))
    {
        //alert("moveright");
        move(id,id+1);
    }
    if(isstart)
    {
        isWin();
    }
}
function setBorder()//设置边界
{
    for(var i=0;i<=picnum;i++)
    {
        $("#"+i).attr({"onclick":null,"class":"border_bg"});
        $("#"+i).css("height","1px");
    }
    for(var i=1;i<=picnum*picnum;i+=picnum)
    {
        $("#"+i).attr({"onclick":null,"class":"border_bg"});
        $("#"+i).css("width","1px");
    }
    for(var i=picnum*(picnum-1)+1;i<=picnum*picnum;i++)
    {
        $("#"+i).attr({"onclick":null,"class":"border_bg"});
        $("#"+i).css("height","1px");
    }
    for(var i=picnum;i<=picnum*picnum;i+=picnum)
    {
        $("#"+i).attr({"onclick":null,"class":"border_bg"});
        $("#"+i).css("width","1px");
    }
}

function move(id,target)//移动
{
    //var temp=$('#'+id).css("background-image");
    //temp=$('#'+id).css("background-image","");
    $('#'+target).css("background-size","cover");
    $('#'+target).css("background-image",$('#'+id).css("background-image"));
    $('#'+id).css("background-image","none");
}
var pic=1;
function init()//初始化图片
{
    for(var i=1;i<picnum-1;i++)
      {
        for(var id=1;id<picnum*picnum;id++)
        {
            if(id>picnum*i+1&&id<picnum*(i+1))
        {
            $('#'+id).css("background-size","cover");
            $('#'+id).css("background-image","url(img/"+level+"/_0"+pic+".jpg)");
            if(id==((picnum-1)*picnum)-1)
            {
                $('#'+id).css("background-image","none");
            }
            pic++;
            //console.log(pic);
        }
        }
      }
}
function saveData()//保存初始数据
{
    for(var i=1;i<picnum-1;i++)
      {
        for(var id=1;id<picnum*picnum;id++)
        {
            if(id>picnum*i+1&&id<picnum*(i+1))
        {
            var temp=$('#'+id).css("background-image");
            picData.push(temp);
        }
        }
      }
}
function startgame()//开始游戏,打乱图片顺序
{
    clearTimeout(timer);
    times=0;timem=0;
    isstart=true;
    var k=0;times=0;timem=0;
    var temp=[];
    for(var i=1;i<(picnum-2)*(picnum-2);i++)
    {
        temp[i-1]=i;
    }
    a_num=getnum(temp);
    for(var i=1;i<picnum-1;i++)
      {
        for(var id=1;id<picnum*picnum;id++)
        {
            if(id>picnum*i+1&&id<picnum*(i+1))
        {
            var temp=$('#'+id).css("background-image","url(img/"+level+"/_0"+a_num[k]+".jpg)");
            k++;
        }
        }
      }
      var temp=picnum*(picnum-1)-1;
      $('#'+temp).css("background-image","none");

      gotime();

}

function getnum(array) //打乱顺序函数
{
    var tmp, current, top =array.length;
    if(top) while(--top){
    current =Math.floor(Math.random() * (top + 1));
    tmp =array[current];
    array[current] =array[top];
    array[top] = tmp;
    }
    return array;
}
function isWin()//判断是否胜利
{
    k=0;
    for(var i=1;i<picnum-1;i++)
      {
        for(var id=1;id<picnum*picnum;id++)
        {
            if(id>picnum*i+1&&id<picnum*(i+1))
        {
            var temp=$('#'+id).css("background-image");
            if(temp==picData[k])
            {
                k++;
            }
        }
        }
      }
      if(k==(picnum-2)*(picnum-2))
      {
          clearTimeout(timer);
          windo();
      }
}

var timem=0;
var times=0;
var timer=null;
function gotime()//开始计时
{
    timer=setTimeout(function(){
        times++;
        if(times>59)
        {
            timem++;
            times=0;
        }
        $('#timer').text(timem+"分"+times+"秒");
        gotime();
},1000);
}
function showpicmain()//显示样本图
{
    $('.pic').css("background-image","url(img/"+level+"/main.jpg)");
}

function windo()
{
    $('.wingame').css("display","block");
    $('.pic2').click(function(){
        $('.wingame').css("display","none");
        startgame();
    });
    $('#timer2').text($('#timer').text());
}

OK,就这样吧,不懂得小伙伴看前面两篇文章。

欢迎学习交流。

by 本该如此

posted @ 2018-11-16 12:42  本该如此  阅读(3412)  评论(7编辑  收藏  举报