flash连连看算法分析及源代码

flash连连看算法分析及源代码

ID:9240729

大小:36.84 KB

页数:11页

时间:2018-04-24

flash连连看算法分析及源代码_第1页
flash连连看算法分析及源代码_第2页
flash连连看算法分析及源代码_第3页
flash连连看算法分析及源代码_第4页
flash连连看算法分析及源代码_第5页
资源描述:

《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

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。