JAVA之连连看算法

http://smqnetwork.blog.51cto.com/771863/196012

连连看连接方式的类型:

l 两点直线法
l 三点直角折线法
l 四点方形折线法
l 四点梯形折线法

下面对上面四种类型进行细致划分讲解:
1. 两点直线法的连接类型包括:上,下,左,右
2. 三点直角折线法包括:上左,上右,下左,下右,左上,右上,左下,右下
3. 四点方形折线法包括:上左下,上右下,下左上,下右上,左上右,右上左,左下右,右下左
4. 四点梯形折线法包括:上左上,下左下,上右上,下左下,左上左,右上右,左下左,右下右

下面关于连连看连接方式类型的讲解

1. 两点直线法:
1. 当两个连接对象在同一横轴坐标,不同纵轴坐标,对象ID要相同(图像相同)第一个对象在第二对象的左边,连接类型为‘右’(向右查找);
[img]
http://extjs2.iteye.com/upload/attachment/140765/4e012f74-3725-3c23-974e-5b6efde92981.png
[/img]
则这一种是不可以连的

从第一个对象的横轴坐标开始向第二个对象靠近,第一个对象在左边,第二对象在右边,此时我们的第一个对象要靠近第二个对象,就必须加上对象宽度等于现在一个虚拟向右移一位的对象,然后将这个虚拟对象去与集合当中的对象的X,Y轴坐标做比较,看在这个的虚拟的对象位子上有没有一个实际对象,首先决定这个虚拟的对象是否于第二个对象的XY轴坐标相同,如果相同就直接返回True,如果有对象就说明这两个对象之间不可连的,则返回false.如果不与第二个对象相等,也没有对象,就继续向第二对象靠近,依次类推,直到找到第二个对象,或中间有阻拦对象,就结束查找。

2. 当两个连接对象在同一横轴坐标,不同纵轴坐标,对象ID要相同(图像相同)第一个对象在第二对象的右边,连接类型为‘左’(向左查找);


[img]/upload/attachment/140767/f1eca7d2-1ef6-3b6f-a642-72b56c1c224c.png[/img]


则这一种是不可以连的

从第一个对象的横轴坐标开始向第二个对象靠近,第一个对象在右边,第二对象在左边,此时我们的第一个对象要靠近第二个对象,就必须减除对象宽度等于现在一个虚拟向左移一位的对象,然后将这个虚拟对象去与集合当中的对象的X,Y轴坐标做比较,看在这个的虚拟的对象位子上有没有一个实际对象,首先决定这个虚拟的对象是否于第二个对象的XY轴坐标相同,如果相同就直接返回True,如果有对象就说明这两个对象之间不可连的,则返回false.如果不与第二个对象相等,也没有对象,就继续向第二对象靠近,依次类推,直到找到第二个对象,或中间有阻拦对象,就结束查找。


3. 当两个连接对象在同一纵轴坐标,不同横轴坐标,对象ID要相同(图像相同),第一对象在第二对象的上方,连接类型为:下(向下查找)

[img]/upload/attachment/140769/17bc973e-0220-31ff-9c9a-c22074d6bf3a.png[/img]

则这一种是不可以连的

从第一个对象的纵轴坐标开始向第二个对象靠近,第一个对象在上边,第二对象在下边,此时我们的第一个对象要靠近第二个对象,就必须加上对象高度等于现在一个虚拟向下移一位的对象,然后将这个虚拟对象去与集合当中的对象的X,Y轴坐标做比较,看在这个的虚拟的对象位子上有没有一个实际对象,首先决定这个虚拟的对象是否于第二个对象的XY轴坐标相同,如果相同就直接返回True,如果有对象就说明这两个对象之间不可连的,则返回false.如果不与第二个对象相等,也没有对象,就继续向第二对象靠近,依次类推,直到找到第二个对象,或中间有阻拦对象,就结束查找。

4. 当两个连接对象在同一纵轴坐标,不同横轴坐标,对象ID要相同(图像相同),第一对象在第二对象的下方,连接类型为:上(向上查找)


[img]/upload/attachment/140771/165a62ad-532c-36cf-b046-7ca2402eb1e3.png[/img]


从第一个对象的纵轴坐标开始向第二个对象靠近,第一个对象在下边,第二对象在上边,此时我们的第一个对象要靠近第二个对象,就必须减除对象高度等于现在一个虚拟向下移一位的对象,然后将这个虚拟对象去与集合当中的对象的X,Y轴坐标做比较,看在这个的虚拟的对象位子上有没有一个实际对象,首先决定这个虚拟的对象是否于第二个对象的XY轴坐标相同,如果相同就直接返回True,如果有对象就说明这两个对象之间不可连的,则返回false.如果不与第二个对象相等,也没有对象,就继续向第二对象靠近,依次类推,直到找到第二个对象,或中间有阻拦对象,就结束查找。



下面来介绍一下我实现的一个连连看界面表现:
游戏开始界面和游戏开始设置界面:
[img]/upload/attachment/140773/ab8289c0-73e2-3655-9493-45e1ff3e7810.png[/img]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值