HTML+Javascript制作拼图小游戏详解(二)
上一篇我们说了网页的基本布局。接下来将为大家带来具体的实现方法。
拼图通表格来实现,做一个方形的表格,改变其大小使之如图所示。
试想一下如果我们将一张图片剪成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制作拼图小游戏详解(二)的更多相关文章
- HTML+Javascript制作拼图小游戏详解(终)
上次我们已经讲解了制作的原理,并且展示了主要代码. 这次我将完整的代码给大家,仅供参考. HTML部分如下: <!DOCTYPE html> <html lang="en& ...
- HTML+Javascript制作拼图小游戏详解(一)
本文章将分享一个来自前端菜鸟突发奇想的拼图游戏制作方法以及实现过程. 话不多说,先上图. 首先我们需要写好网页的基本布局(此处涉及简单的HTML和CSS知识). 网页一共分为三个区域,左侧时间显示区, ...
- JavaScript版拼图小游戏
慕课网上准备开个新的jQuery教程,花了3天空闲时间写了一个Javascript版的拼图小游戏,作为新教程配套的分析案例 拼图游戏网上有不少的实现案例了,但是此源码是我自己的实现,所以不做太多的比较 ...
- java贪吃蛇小游戏详解
https://blog.csdn.net/u011622021/article/details/81162083
- 壁球小游戏详解(附有源码.cpp)
1.在python中安装pygame 2.将下列源码复制过去,运行. #引用 import pygame, sys #初始化 pygame.init() size = width, height = ...
- 教你用Python自制拼图小游戏,一起来制作吧
摘要: 本文主要为大家详细介绍了python实现拼图小游戏,文中还有示例代码介绍,感兴趣的小伙伴们可以参考一下. 开发工具 Python版本:3.6.4 相关模块: pygame模块: 以及一些Pyt ...
- javascript中=、==、===区别详解
javascript中=.==.===区别详解今天在项目开发过中发现在一个小问题.在判断n==""结果当n=0时 n==""结果也返回了true.虽然是个小问题 ...
- 使用NGUI实现拖拽功能(拼图小游戏)
上一次用UGUI实现了拼图小游戏,这次,我们来用NGUI来实现 实现原理 NGUI中提供了拖拽的基类UIDragDropItem,所以我们要做的就是在要拖拽的图片上加一个继承于该类的脚本,并实现其中的 ...
- jQuery拼图小游戏
jQuery拼图小游戏 最后样式 核心代码部分 <script type="text/javascript" > $(function () { $("td& ...
随机推荐
- 1、HttpClient初探
HttpClient是它的核心接口.可以理解为一个简单的浏览器. 主要方法有: getParams(); 获取运行参数 getConnectionManager(); 获取连接管理器.连接管理器中 ...
- Devexpress VCL Build v2014 vol 14.2.5 发布
和xe8 几乎同一天出来,但是目前官方不支持xe8. The following sections list all minor and major changes in DevExpress VCL ...
- 基于beego orm 针对oracle定制
目前golang的ORM对oracle支持都没有mysql那样完整,一个orm要同时兼容mysql和oracle由于在sql语法上区别,会使整orm变的非常臃肿. 本项目是在beego orm上修改, ...
- hfs快速搭建HTTP文件服务器
HFS全称为http file server,他是一个专门实现文件共享的工具,通过WWW服务将要共享的目录或文件发布,从而让需要下载者直接通过IE浏览器访问发布的这个共享站点,然后随意下载共享资源.和 ...
- yum基本操作(转)
原文地址:http://www.cnblogs.com/chuncn/archive/2010/10/17/1853915.html yum(全称为 Yellow dog Updater, Modif ...
- 如何在MAC下安装Myeclipse2015真的很虐心!!!!!!!!!!
最近笔者换了一个新的笔记本,mac pro 因为同学说大公司的web开发都是写在Linux操作系统下的,所以我决定搞一个,但是装软件就是很困难啊!找了大量资料发现都不全,最后,终于搞好了,分享给同样虐 ...
- java.lang.NoClassDefFoundError: org/hamcrest/SelfDescribing,
缺少一个java包,然后我在这个网址找到了http://central.maven.org/maven2/org/hamcrest/hamcrest-core/1.3/hamcrest-core-1. ...
- UVaLive 3487 Duopoly (最小割)
题意:有两个公司A和B在申请一些资源,现在给出两个公司所申请的内容,内容包括价钱和申请的资源 ,现在你做为官方,你只能拒绝一个申请或者接受一个申请,同一个资源不能两个公司都拥有,且申请的资源不能只给部 ...
- java的IO操作
转自http://zhangbaoming815.iteye.com/blog/1578438 将字符串写入到txt文件中import java.io.BufferedWriter; import j ...
- Center Alignment
http://acm.hust.edu.cn/vjudge/contest/view.action?cid=93359#problem/B(456321) http://codeforces.com/ ...