贪吃蛇游戏(五)——添加交互操作(完结篇)

接上文

http://www.jianshu.com/p/ee2851d8cc7d

本节是这个系列的最后一节了。本节中,将增加蛇的方向,增加用户交互操作,增加开始暂停等等。

1 增加方向
在手机屏幕上,贪吃蛇的移动方向只有四种,上,下,左,右。我们将这四种方向,定义成一个枚举。创建一个新的文件,Direciton.swift(file->new-file,过程不赘述)。
在Direction.swift中添加如下代码:

enum Direction {
    case UP
    case DOWN
    case LEFT
    case RIGHT
}

之后我们在Snake.swift中添加Direction的扩展,在扩展中,我们定义两个函数,walk()和changeDirection()。分别描述蛇的前进和方向的变化。对于walk函数,传入的参数为当前蛇头的坐标,我们根据当前的方向,修改坐标。对于changeDirection函数,传入参数有两个,分别为蛇头的当前坐标和用户的点击坐标(根据点击坐标决定蛇的新方向),代码如下:

extension Direction {
    func walk(inout point: CGPoint) {
        switch self {
        case .UP: point.y -= CGFloat(30)
        case .DOWN: point.y += CGFloat(30)
        case .LEFT: point.x -= CGFloat(30)
        case .RIGHT: point.x += CGFloat(30)
        }
    }
    
    mutating func changeDirection(cur: CGPoint, target: CGPoint) {
        switch self {
        case .UP: self = cur.x > target.x ? .LEFT : .RIGHT
        case .DOWN: self = cur.x > target.x ? .LEFT : .RIGHT
        case .LEFT: self = cur.y > target.y ? .UP : .DOWN
        case .RIGHT: self = cur.y > target.y ? .UP : .DOWN
        }
    }
}

之后在Snake中添加对Direction属性,在 weak var mainView: UIView!下面添加如下代码:

var direction = Direction.RIGHT

然后修改Snake.walk函数,删除原来的代码,改为如下代码:

direction.walk(&head.frame.origin)

并在Snake中添加修改方向的操作

func changeDirection(point: CGPoint) {
    direction.changeDirection(head.frame.origin, target: point)
}

完成以上操作后,我们还需要添加贪吃蛇吃掉食物的操作。当贪吃蛇吃掉一个食物时,需要增加一段身体,因此继续在Snake中添加如下代码:

func eat() {
    body.addOne(mainView)
}

2 增加用户交互
有了方向修改操作后,我们需要用户通过点击屏幕来触发修改蛇的运动方向。在左侧导航栏中点击Main.storyboard,在右下角的filter中输入tap,找到Tap Gesture,将其拖到我们的view中。



操作完成后,会在Main.storyboard中出现手势操作的标识,如下:



点击手势操作标识,并按住control键,拖动到SnakeViewController的walk后面,Connection选择action,Type选择UITapGesture...,Name填写changeDirection,之后点击connect如图所示:

在changeDirection中添加如下代码:
@IBAction func changeDirection(sender: UITapGestureRecognizer) {
    let tapPoint = sender.locationInView(self.view)
        
    snake.changeDirection(tapPoint)
}

之后点击运行,当贪吃蛇运行过程中,我们点击屏幕,可以发现小蛇根据我们的点击位置,自动的改变方向了。


3 增加开始暂停
点击Main.storyboard,在右下角的filter中输入bar button item,找到Bar Button Item,拖动到导航栏的左下角位置,如图:



点击新的item,在右侧的属性栏里,将Title修改为『暂停』



点击新增加的item button,并按住control键,和上面的操作一样,增加pause函数。当用户点击暂停时,我们将当前的定时器暂停,当用户再次点击时恢复,并修改title,代码如下:
var isPause = false

@IBAction func pause(sender: UIBarButtonItem) {
    isPause = !isPause
            
    if (isPause) {
        sender.title = "开始"
        timer.fireDate = NSDate.distantFuture()
    } else {
        sender.title = "暂停"
        timer.fireDate = NSDate.distantPast()
    }
}

点击左上角的运行,我们可以发现当点击『暂停』时,小蛇就停住了,再次点击『开始』时,又动了起来。

4 增加吃食物判断逻辑
当蛇头的坐标和食物的坐标相同时,我们判定吃食成功,则触发两个操作,a 修改食物的坐标,b 增加蛇的长度。将SnakeViewController.walk的定义修改成如下代码:

var score = 0 //记录分数

func walk() {
    if food.frame.origin == snake.head.frame.origin {
        food.changeFood(food)
        snake.eat()
        score += 10
        navigationItem.title = String(score)
    }
        
    snake.walk()
}

我们同时增加了一个计分操作,如代码中所示。
点击左上角的运行,当小蛇完成吃食操作时,它的长度增加了。

5 边界处理
目前为止,贪吃蛇已基本全部完成了。但是当它到了屏幕的边界时,会继续往前,这样就脱离我们的视线了。因此我们增加逻辑,当碰触屏幕边缘时,修改蛇的坐标,让它从另一边重新出现。在左侧找到ListBodyItem,在SnakeHead中增加touchEdge函数,代码如下:

func touchEdge(){
    if (frame.origin.x < 0) {
        frame.origin.x = 330
    } else if (frame.origin.x > 330) {
        frame.origin.x = 0
    } else if (frame.origin.y < 60) {
        frame.origin.y = 630
    } else if (frame.origin.y > 630) {
        frame.origin.y = 60
    }
}
![snake.gif](http://upload-images.jianshu.io/upload_images/1397675-f0f86b83cf3fcdbf.gif?imageMogr2/auto-orient/strip)

之后在Snake的walk中增加对touchEdge的调用,如下:

func walk() {
    direction.walk(&head.frame.origin)
    head.touchEdge()
}

点击左上角的运行,现在当小蛇到达屏幕边缘时,会『神奇』的从另一边出现了。


最终的效果图:


snake.gif

项目的github如下:

https://github.com/littlersmall/snake/tree/master

总结
1 swift蛮好用的
2 iOS做界面开发的学习曲线挺平滑的
3 素材真的很难找,适配屏幕调整图片尺寸很费劲

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

推荐阅读更多精彩内容