Android 2048

先上个成品图

成品图.gif

实现:

就俩对象:CardView、GameView

·CardView:卡片类(每个数字方块对应的对象)

属性:取值(value),取值如:2,4,8,16....2048                                                                                     颜色(color),不同的取值有对应不同的颜色值(我是通过colorspy一个一个取的==)

方法:同时这个类暴露一个setValue方法来改变方块的取值。调用这个方法的同时不仅要改变               value的值,由于value的改变而带来color的变化,所以需要调用invalidate方法来重绘这             个View,(PS这里还有个缩放动画)。

注意: 1)这是一个圆角矩形。绘制圆角矩形有两种方法:canvas.drawRoundRect(rectf,                        radius,radius, paint)、canvas.drawRoundRect(l, t, r, b, rx, ry, paint)。我使用的是第一                种,因为可以兼容到21以下。                                                                                                        2)这次我才发现自定义View如果要可以wrap_content的话,需要重写onMeasure方法。              哈,不要笑我,我之前就知道重写onDraw。主要搞清楚MeasureSpec的三种Mode就可              以了(AT_MOST,EXACTLY和UNSPECIFIED)。网上有很多文章,我这里不说了哈。

·GameView:游戏主界面

这是一个ViewGroup,这是我第一自定义ViewGroup吼吼吼。最重要的就是重写onLayout方法,告诉它每一个子View要摆在哪。具体请阅读hongyang大神的博客之 Android 手把手教您自定义ViewGroup(一)


GameView.jpg

游戏中,我们可以注意到每个卡片移动后,它的背景就显示出来了(或者说它的位置就空出来了)。我把这些背景看做是16个值为0的CardView。这16个背景(或者说空位)的位置是不会变化的。用一个List来维护这16个背景,每次onLayout的时候,把它们绘制到对应的位置上即可。

再次就是那些可以移动的卡片了,因为它们出现的位置并不固定,而且有的位置可以为空,并且可能不连续,所以我用一个HashMap来维护它们,HashMap的键用来存储它的位置(index),值来存对应的CardView。

onLayout.jpg

接下来,我们要重写onTouchEvent方法来监听它的触摸事件,判断用户是进行的操作是否有效,进行了什么操作。具体实现就是在ACTION_DOWN的时候把触碰点的xy坐标记录下来,在ACTION_MOVE的时候和当前的的坐标进行对比。不细说了。需要注意的是,只要进行了有效的滑动,就会触发相关事件(例如卡片的移动,卡片的合并),那么这次(到ACTION_UP为止)的触碰事件就结束了,继续移动是不会再次触发的。

在说卡片的移动和合并之前,再说一个比较简单的细节。每次移动后都会在随机的一个空位中出现一个2或者4。


随机数.jpg


最后来说一下卡片的移动和合并,其实这一步如果不给卡片的移动加上动画并不难。那就先说不加动画的吧。

用向左移动当做例子吧:我们只需要看一行,其他行循环处理就行(用i的循环行)。从左向右看(用j来循环列),会有如下两种情况:

如果这个位置上(j)的CardView是空的话,我们要从这一行的(j+1)开始去寻找第一个不为空的CardView,让它移动到j上。j不变。如果找了一圈没找到的话,那说明j之后已经没有CardView了, 这个循环就可以break了。

如果这个位置上的CardView不为空的话,同样我们要从这一行的(j+1)开始去寻找第一个不为空的CardView,如果它的value和当前CardView(j)上的value相同的话,就把当前CardView的值加倍,把找到的位置上的CardView置空。j++。如果找了一圈没找到的话,那说明j之后已经没有CardView了, 这个循环就可以break了。

其他三种情况是类似的。我就不多讲了。其实逻辑并不复杂。

加上动画就麻烦了。我们知道动画的执行是需要时间的。如果在动画执行期间,已经进入了下一次的循环,就会导致数据混乱。我的做法就是添加一个布尔类型的全局变量(isMoveAnimating),在动画执行期间它的值是true,只有它执行完成后才回变成false。只有当isMoveAnimating为false的时候循环才能继续。但是,还是以向左移动为例,它每一行之间动画的执行是不会互相影响的,所以就考虑到把每一行要做的事情抽取出来变为一个单独的Thread,而isMoveAnimating就是每一个Thread的局部变量,不会互相影响。


MoveThread



MoveRunnable
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,499评论 25 707
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,724评论 0 33
  • 内容抽屉菜单ListViewWebViewSwitchButton按钮点赞按钮进度条TabLayout图标下拉刷新...
    皇小弟阅读 46,708评论 22 664
  • 小游 你以后就不要姓游了 我姓游 你姓游 别人还以为 咱俩是亲戚哩 说我游某人 任人唯亲 其实咱俩是八竿子 打不着...
    关中陈镜阅读 150评论 0 1
  • 去到糟糕的地方,曾气急败坏得说,没有下次了。 可是机缘总是遇到巧合,又来了,还不止一次。 离别前夕也曾信誓旦旦说,...
    大兰大兰兰阅读 242评论 0 0