查看: 746|回复: 0
打印 上一主题 下一主题

[其他] 消星星的同颜色算法

[复制链接]
may    

8830

主题

80

听众

7万

积分

首席设计师

Rank: 8Rank: 8

纳金币
52312
精华
343

最佳新人 热心会员 灌水之王 活跃会员 突出贡献 荣誉管理 论坛元老

跳转到指定楼层
楼主
发表于 2019-12-15 10:16:26 |只看该作者 |倒序浏览
[backcolor=rgba(255, 255, 255, 0.8)]参考:[backcolor=rgba(255, 255, 255, 0.8)][url=]https://blog.csdn.net/dengminghli/article/details/84147675[/url]
  1.     int[] xx = { 1, 0, 0, -1 };
  2.     int[] yy = { 0, 1, -1, 0 };
  3.     int[,] visit = new int[10, 10];//为了防止重复访问
  4.     GameObject[] objList = new GameObject[10 * 10];//用来保存相同颜色的色块
  5.     GameObject[,] curObj = new GameObject[10 , 10];//当前所有的方个中的颜色

  6.     int index = 0;//计数
  7.     void HellowWorld(GameObject obj)
  8.     {
  9.         //获得当前色块的坐标
  10.         int x = (int)obj.transform.position.x;
  11.         int y = (int)obj.transform.position.y;
  12.         visit[x, y] = 1;//1表示访问过这个色块
  13.         objList[index++] = obj;//添加当前颜色块
  14.         //循环,实现四个方向的轮询
  15.         for (int i = 0; i < 4; i++)
  16.         {
  17.             //获取第一个方向:根据xx和yy的顺序调整
  18.             int x1 = x + xx[i];
  19.             int y1 = y + yy[i];
  20.             if (x1 >= 0 && x1 < 10 && y1 >= 0 && y1 < 10)//判断出界
  21.             {
  22.                 if (visit[x1, y1] == 0 && curObj[x1, y1].name == obj.name)//没有访问过,如果符合相同颜色
  23.                 {
  24.                     HellowWorld(curObj[x1,y1]);
  25.                 }
  26.             }
  27.         }
  28.     }
复制代码
分享到: QQ好友和群QQ好友和群 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
转播转播0 分享淘帖0 收藏收藏0 支持支持0 反对反对0
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

关闭

站长推荐上一条 /1 下一条

手机版|纳金网 ( 闽ICP备08008928号

GMT+8, 2024-5-18 10:53 , Processed in 0.081216 second(s), 29 queries .

Powered by Discuz!-创意设计 X2.5

© 2008-2019 Narkii Inc.

回顶部