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

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

试想一下如果我们将一张图片剪成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. jsp札记

    日期格式化 <s:date name="creaetime" format="yyyy-MM-dd HH:mm:ss" /> <base hr ...

  2. Proximal Algorithms

    1. Introduction Much like Newton's method is a standard tool for solving unconstrained smooth minimi ...

  3. PHP compact函数

    $firstname = "Peter"; $lastname = "Griffin"; $age = "41"; $data = comp ...

  4. S3 exercise -- 文件操作&函数

    编码 请说明python2 与python3中的默认编码是什么? # 答案 py2默认ASCII码,py3默认的utf8 为什么会出现中文乱码?你能列举出现乱码的情况有哪几种? # 答案 #codin ...

  5. Field '***********' doesn't have a default value

    今天做配置文件一直报这个错误: 原因是主键是integer类型,没有设置自增模式,所以会出现这个问题,是表的结构问题.更改用navicat

  6. Mybatis实现原理探究-实现部分Mybatis功能(上)

    一.前言: MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以使用简 ...

  7. python编码(三)

    python 有str object 和 unicode object 两种字符串,都可以存放字符的字节编码,但是他们是不同的type,这一点很重要,也是为什么会有encode(编码)和decode( ...

  8. 01-html和head介绍

    一.web标准 web准备介绍: w3c:万维网联盟组织,用来制定web标准的机构(组织) web标准:制作网页遵循的规范 web准备规范的分类:结构标准.表现标准.行为标准. 结构:html.表示: ...

  9. QGIS 2014年7月18日版本

    4. Building on Windows 4.1. Building with Microsoft Visual Studio This section describes how to buil ...

  10. 配置使用sourcemap调试vue源码爬坑

    环境: Google Chrome  V72.0.3626.109 vue-dev V 2.6.10 爬坑的乐趣就不说了(我恨啊),以下说一下出坑要点 1. 在vue-dev的package.json ...