上一篇我们说了网页的基本布局。接下来将为大家带来具体的实现方法。

拼图通表格来实现,做一个方形的表格,改变其大小使之如图所示。

试想一下如果我们将一张图片剪成6张分别放入对应位置,然后再把它打乱,这样就可以进行拼图了。

可是,将图片放入和打乱图片倒是不难,可想要实现移动图片,这就有一点麻烦了。

不知道别人使用的什么方法,博主接下来会讲一种非常简单的办法去实现移动图片。

(ps:博主正在尝试通过HTML5的新特性去实现图片的拖拽移动,貌似不太理想。。。)

目前博主只能通过给表格留一个空白处作为移动区,如图。

当你点击一张图片之后他会检测图片的上下左右哪个方向存在空白区,

接着将点击的图片与空白区想对换,

简单来说就是把点击区域的背景给空白区,

再删除点击区域的图片,这样看起来就像是移动了。

道理都懂,接下来就让我们回归实际,看一看代码应该怎么写。

function movepic(id)//移动图片函数,接受点击图片(需要移动图片)的id值
{
//我们通过一个函数iskong(id)来判断该位置是否存在图片
  //picnum为我们申明的全局变量用于存储拼图的大小(n*n)
  if(iskong(id-picnum))//点击图像上方是否为空
{
//alert("moveup");
move(id,id-picnum);//move()为执行的移动函数需要传两个值,一个移动元素id,另一个为目标id
}
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)//isstart判断是否已经开始游戏
{
isWin();//每次移动后判断是否完成拼图
}
}

这里是移动图片所需要调用的函数

function iskong(id)//判断改标签是否为空
{ var bg=$('#'+id).css("background-image");
if(bg=="none"){
return true;
}else
{
return false;
}
}
 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"));//把需要移动的表格td的背景给目标td(当然也可以用img标签)
   $('#'+id).css("background-image","none");
 } 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])//picData[k]为初始化拼图时所存储的每个图片顺序等信息
{
k++;
}
}
}
}
if(k==(picnum-2)*(picnum-2))//如果k等于图片总数表示图片和初始化时完全一致,这个时候就会执行赢的函数
{
clearTimeout(timer);//这里的timer为我们的计时器
windo();//胜利时执行该函数
}
}
function windo()//游戏胜利后执行
{
$('.wingame').css("display","block");//显示胜利的窗口
$('.pic2').click(function(){
$('.wingame').css("display","none");
startgame();
});
$('#timer2').text($('#timer').text());//显示所用时间
}

哈哈哈,这次就写这么多吧,博主我要看电影去了。(我买两千万德国赢,那部)

基本思路就是这样。

等我改天整理一下发完整的代码。

目前没有整理有点乱。。。

ps:博主小白 勿喷 勿喷 勿喷

欢迎指导交流,接受批评。

回见。

HTML+Javascript制作拼图小游戏详解(二)的更多相关文章

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

    上次我们已经讲解了制作的原理,并且展示了主要代码. 这次我将完整的代码给大家,仅供参考. HTML部分如下: <!DOCTYPE html> <html lang="en& ...

  2. HTML+Javascript制作拼图小游戏详解(一)

    本文章将分享一个来自前端菜鸟突发奇想的拼图游戏制作方法以及实现过程. 话不多说,先上图. 首先我们需要写好网页的基本布局(此处涉及简单的HTML和CSS知识). 网页一共分为三个区域,左侧时间显示区, ...

  3. JavaScript版拼图小游戏

    慕课网上准备开个新的jQuery教程,花了3天空闲时间写了一个Javascript版的拼图小游戏,作为新教程配套的分析案例 拼图游戏网上有不少的实现案例了,但是此源码是我自己的实现,所以不做太多的比较 ...

  4. java贪吃蛇小游戏详解

    https://blog.csdn.net/u011622021/article/details/81162083

  5. 壁球小游戏详解(附有源码.cpp)

    1.在python中安装pygame 2.将下列源码复制过去,运行. #引用 import pygame, sys #初始化 pygame.init() size = width, height = ...

  6. 教你用Python自制拼图小游戏,一起来制作吧

    摘要: 本文主要为大家详细介绍了python实现拼图小游戏,文中还有示例代码介绍,感兴趣的小伙伴们可以参考一下. 开发工具 Python版本:3.6.4 相关模块: pygame模块: 以及一些Pyt ...

  7. javascript中=、==、===区别详解

    javascript中=.==.===区别详解今天在项目开发过中发现在一个小问题.在判断n==""结果当n=0时 n==""结果也返回了true.虽然是个小问题 ...

  8. 使用NGUI实现拖拽功能(拼图小游戏)

    上一次用UGUI实现了拼图小游戏,这次,我们来用NGUI来实现 实现原理 NGUI中提供了拖拽的基类UIDragDropItem,所以我们要做的就是在要拖拽的图片上加一个继承于该类的脚本,并实现其中的 ...

  9. jQuery拼图小游戏

    jQuery拼图小游戏 最后样式 核心代码部分 <script type="text/javascript" > $(function () { $("td& ...

随机推荐

  1. 执行程序---system

    头文件:#include<stdlib.h> 函数原型:int system(const char *command) 参数说明:command被执行的命令,字符串格式 返回值:成功则返回 ...

  2. 2018.10.23 hdu4745Two Rabbits(区间dp)

    传送门 区间dp经典题目. 首先断环为链. 然后题目相当于就是在找最大的回文子序列. 注意两个位置重合的时候相当于范围是n,不重合时范围是n-1. 代码: #include<bits/stdc+ ...

  3. trcd_extract_EDCD_new

    # -*- coding:utf-8 -*- import re ''' 适应新版本 ''' year='17A'#用户自定义 ss='./data/'#根目录 filename = ss+'EDCD ...

  4. (KMP 模板)Number Sequence -- Hdu -- 1711

    http://acm.hdu.edu.cn/showproblem.php?pid=1711 Number Sequence Time Limit: 10000/5000 MS (Java/Other ...

  5. idea 优化

    http://www.iyunv.com/thread-348537-1-1.html

  6. PAT甲 1046. Shortest Distance (20) 2016-09-09 23:17 22人阅读 评论(0) 收藏

    1046. Shortest Distance (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue The ...

  7. C++中的乱七八糟问题

    1   在编写的c++程序中,如果是窗口,有时会一闪就消失了,如果不想让其消失,在程序结尾处添加: #include“iostream.h” system("pause"); 分析 ...

  8. hdu 4952 暴力

    http://acm.hdu.edu.cn/showproblem.php?pid=4952 给定x,k,i从1到k,每次a[i]要是i的倍数,并且a[i]大于等于a[i-1],x为a0 递推到下一个 ...

  9. javascript data format

    Date.prototype.Format = function(fmt) { var o = { "M+" : this.getMonth()+1, //月份 "d+& ...

  10. D3 drag

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...