欢迎来到天天文库
浏览记录
ID:9240729
大小:36.84 KB
页数:11页
时间:2018-04-24
《flash连连看算法分析及源代码》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、FLASH连连看算法分析及源代码做FLASH连连看有特别之处,下面我们就详细分析FLASH连连看的算法。在做连连看之前,我们根据折线数的不同分为3种情况: 第一种情况:如图,方块1与方块2在同一水平线上,方块1与方块3在同一垂直线上,这就是我们的第一种情况:在实际应用时,我们在1和2之间或1和3之间实例化一条线段,用hitTestObject来测试,如果与这条线段相交的图片个数小于等于2,那么这两个图片就是连通的。第二种情况:就是2和3的关系了,在2和3之间实例化四条线段,两个水平的,两个垂直的,如下图所示:与A相交的图片数加上与B
2、相交的图片数小于等于2或者与C相交的图片数加上与D相交的图片数小于等于2,那么这两个图片就是连通的。第三种情况:第三种情况主要与前两种情况配合使用,如果前两种情况测试不成功,那么直接跳转到第三种情况,如果第三种情况测试依然不成功,那么这两个图片不连通,也就是说用户进行了一次错误操作。第三种情况比较复杂,测试两个图片是否连通分为两种情况,一种是A线段是水平的(垂直扫描),另一种是A线段是垂直的(水平扫描)。1.A线段是水平的,我们要平均间隔垂直扫描并实例化A线段,只有在测试到与A相交的图片数为0时,跳出扫描的循环,并且实例化B线段和C线段
3、,如果与B线段相交的图片数加上与C线段相交的图片数小于等于2,则两个图片连通。2.A线段是垂直的,算法与上者相同,只是扫描的方向不同。好了,下面我们来亲手做一个简单的连连看。我们这个连连看很简单,只要按照下面的操作就可以了。若要运行此示例,请确保在FLASH文件同目录下有一个images文件夹,其中有1.gif,2.gif,3.gif...40.gif共40个32*32像素的gif格式的图片。打开flashcs3,新建一个FLASH文档,在文档类中填写simplellk,在同目录下新建一个AS文件,名为simplellk.as,在其中输
4、入以下代码:package{/**连连看原始模型,供AS3交流所用*/importflash.display.Sprite;importflash.display.Loader;importflash.net.URLRequest;publicclasssimplellkextendsSprite{ privatevarmyllk:llk; privatevarmyllkarr:Array=newArray; privatevarimage:Loader; publicfunctionsimplellk():void{ se
5、tlisteners(); addllk(); } privatefunctionsetlisteners():void{ stage.addEventListener("mouseDown",click_stage); stage.addEventListener("keyUp",keyup); } privatefunctionkeyup(event):void{ if(event.keyCode==116){ pl(); } } privatefunctionaddllk():void{
6、for(vari:int=0;i<80;i++){ myllk=newllk; image=newLoader; image.load(newURLRequest("images/"+((i%40)+1)+".gif")); myllk.addChild(image); myllk.x=30+(i%10)*40; myllk.y=30+Math.floor(i/10)*40; myllkarr.push(myllk); addChild(myllk); } pl();//reset
7、 } privatefunctionclick_stage(event):void{ for(variinmyllkarr){ if(myllkarr[i].hitTestPoint(mouseX,mouseY)){ myllkarr[i].selected=!myllkarr[i].selected; myllkarr[i].show_selected(); for(varjinmyllkarr){ if(j!=i&&myllkarr[j].selected&&j%(myllkarr.l
8、ength/2)==i%(myllkarr.length/2)){ if(testbylevel(i,j)){ myllkarr[i].removethis(); m
此文档下载收益归作者所有