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

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

试想一下如果我们将一张图片剪成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. asio 广播代码示例

    代码网络收集 修改了一个编译的小问题 客户端 // Client.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include < ...

  2. 661. Image Smoother

    static int wing=[]() { std::ios::sync_with_stdio(false); cin.tie(NULL); ; }(); class Solution { publ ...

  3. yii框架场景的用法

    1.在 model 里面定义一下场景 类名必须是 scenarios() public function scenarios() { return [ 'create' => ['title', ...

  4. hdu-1176(动态规划)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1176 思路:类似数塔问题, 从最后一秒开始考虑,每次这一秒的状态确定意味着前一秒的状态也已经确定,所以 ...

  5. wadl 的自动生成(cxf版本2.7.6)

    参考文档 http://cxf.apache.org/docs/jaxrs-services-description.html 获取项目 git@github.com:witaste/cxf-2.7. ...

  6. c++中sort()及qsort()的用法总结

    当并算法详解请见点我 想起来自己天天排序排序,冒泡啊,二分查找啊,结果在STL中就自带了排序函数sort,qsort,总算把自己解脱了~ 所以自己总结了一下,首先看sort函数见下表: 函数名 功能描 ...

  7. Python学习-32.Python中os模块的一些方法

    首先肯定是要引入os模块了. import os getcwd方法: print(os.getcwd()) 上面的语句将会输出当前的工作目录,相当于C#中的Environment.CurrentDir ...

  8. wsdl 结构解析

    webservice的跨平台特性要求它必须有某种手段来对服务进行自我描述,使不同的语言能正确理解如何调用该服务.webservice通过WSDL(Web Services Description La ...

  9. paxos ---学习笔记

    摘自维基百科:分布式系统中的节点通信存在两种模型:共享内存(Shared memory)和消息传递(Messages passing).基于消息传递通信模型的分布式系统,不可避免的会发生以下错误:进程 ...

  10. CSharp程序员学Android开发---3.Android内部元素不填充BUG

    最近公司组织项目组成员开发一个Android项目的Demo,之前没有人有Andoid方面的开发经验,都是开发C#的. 虽说项目要求并不是很高,但是对于没有这方面经验的人来说,第一步是最困难的. 项目历 ...