贪吃精灵小游戏demo

作者: HelloYeah | 来源:发表于2016-03-17 18:25 被阅读443次

导读

  • 下了班,闲着没事,写了两个小demo分享给大家练练手.一个通过简单动画完成的,另一个是绘图.你能1个小时写完俩个吗,在不参考源码的情况下,那说明你的动画和绘图掌握的很不错了.要是没能写出来,也不需要气馁,多敲敲你就掌握了.
下面这个是贪吃精灵小游戏demo的效果图.怎么样,看效果还挺不错吧!

源码链接https://github.com/newyeliang/EatDoudou欢迎star

2.gif
  • 核心代码
  //判断方向,往不同的方向移动
- (void)moveAnimation{
    
    CGPoint center = self.eat.center;
    
    switch (self.direction) {
            
        case DirectionUp:{
             self.eat.image = [UIImage imageNamed:@"3"];
            [UIView animateWithDuration:0.05 animations:^{
                self.eat.center = CGPointMake(center.x,center.y - self.speed);
            }];
            [self result];
        }
            break;
        
        case DirectionLeft:{
            self.eat.image = [UIImage imageNamed:@"2"];
            [UIView animateWithDuration:0.05 animations:^{
                self.eat.center = CGPointMake(center.x - self.speed,center.y );
            }];
            [self result];
        }

            break;
        case DirectionDown:{
            self.eat.image = [UIImage imageNamed:@"4"];
            [UIView animateWithDuration:0.05 animations:^{
                self.eat.center = CGPointMake(center.x,center.y + self.speed);
            }];
            [self result];
        }
            break;

        case DirectionRight:{
        
            self.eat.image = [UIImage imageNamed:@"1"];
            [UIView animateWithDuration:0.05 animations:^{
                self.eat.center = CGPointMake(center.x + self.speed,center.y );
            }];
            [self result];
            
        }
            
            break;
            
        default:
            break;
    }
}

游戏结果判断代码

    //计算游戏的分数,判断是否超出边界
- (void)result{

    //eat 和 doudou相交,分数+100
    if (CGRectIntersectsRect(self.eat.frame,self.doudou.frame)) {
        //移除原来的豆豆
        [self.doudou removeFromSuperview];
        
        self.speed += 1;
        
        self.scoreLabel.text = [NSString stringWithFormat:@"Score:  %d",(int)(self.speed - 3) * 100];
        //添加新的豆豆
        self.doudou;
    }
    
    //超出边界,游戏结束
    if ( CGRectGetMaxX(self.eat.frame) > self.backgroundView.bounds.size.width ||CGRectGetMaxY(self.eat.frame) > self.backgroundView.bounds.size.height||CGRectGetMinX(self.eat.frame) < 0||CGRectGetMinY(self.eat.frame) < 0) {
        
        [self.timer invalidate];
        [self.eat removeFromSuperview];
        
        //game over 提示框
        UILabel * deathTip = [[UILabel alloc]init];
        deathTip.text = @"Game Over!!!";
        deathTip.backgroundColor = [UIColor whiteColor];
        [deathTip sizeToFit];
        [self.backgroundView addSubview:deathTip];
        deathTip.center = self.backgroundView.center;
        
        [UIView animateWithDuration:4.0 animations:^{
            deathTip.alpha = 0.0;
        } completion:^(BOOL finished) {
            [deathTip removeFromSuperview];
        }];
    }
}

第二个是个太极图,看起来是不是很简单,你能画出来吗?打开Xcode试试吧!!!
3.gif
  • 核心代码

源码链接https://github.com/newyeliang/TaiJIAnimation.git

    //绘制太极图
- (void)drawImage:(CGSize)size{
    
    float mid = size.width/2;
    
    //1.开启图像上下文
    UIGraphicsBeginImageContext(size);

    //2.获取上下文
    CGContextRef ctx = UIGraphicsGetCurrentContext();
    
    //3.绘图
        //3.1 绘制黑色的半边
    CGContextAddArc(ctx, mid, mid, mid, - M_PI_2, M_PI_2, 0);
    CGContextAddArc(ctx, mid, mid + 0.5 * mid, mid * 0.5, M_PI_2, -M_PI_2, 1);
    CGContextAddArc(ctx, mid, 0.5 * mid, mid * 0.5, M_PI_2, -M_PI_2, 0);
    [[UIColor blackColor]set];
    CGContextFillPath(ctx);
        //3.2绘制白色的半边
    CGContextAddArc(ctx, mid, mid, mid, - M_PI_2, M_PI_2, 1);
    CGContextAddArc(ctx, mid, mid + 0.5 * mid, mid * 0.5, M_PI_2, -M_PI_2, 1);
    CGContextAddArc(ctx, mid, 0.5 * mid, mid * 0.5, M_PI_2, -M_PI_2, 0);
    [[UIColor whiteColor]set];
    CGContextFillPath(ctx);
    
        //3.3绘制白色的小圆
    CGContextAddArc(ctx, mid, 0.5 * mid, 0.2 * mid, M_PI,- M_PI , 1);
    CGContextFillPath(ctx);
        //3.4绘制黑色的小圆
    CGContextAddArc(ctx, mid, 1.5 * mid, 0.2 * mid, M_PI,- M_PI , 1);
    [[UIColor blackColor]set];
    CGContextFillPath(ctx);

    //4.获取生成的图片
    UIImage *image=UIGraphicsGetImageFromCurrentImageContext();
    //5.显示生成的图片到imageview
    self.backgroundColor = [UIColor colorWithPatternImage:image];
    UIGraphicsEndImageContext();

}

相关文章

  • 贪吃精灵小游戏demo

    导读 下了班,闲着没事,写了两个小demo分享给大家练练手.一个通过简单动画完成的,另一个是绘图.你能1个小时写完...

  • 游戏 & Github Page

    1. snakewizard.github.io 贪吃蛇小游戏 2. mattbasile.github.io 龙...

  • 童话故事:贪吃小精灵

    你知道贪吃精灵吗?那是一种非常可爱的小精灵,不过她们可是一群贪吃的小家伙,如果你仔细在厨房里找一找的话,说不定也能...

  • 《极限贪吃蛇》

    贪吃蛇是一款非常有趣的小游戏。 益智有好玩,等你来体验

  • 小游戏 贪吃蛇

    内容 贪吃蛇游戏包含:1.游戏引擎,2.蛇,3.食物。 基本操作 蛇会自动走,键盘可控制方向(上下左右),碰到边界...

  • 贪吃的魔怪10

    老奶奶和小魔怪带着贪吃的毛毛菜走出了贪吃树,而且随身还携带了贪吃树精灵们送的衣服——可以躲避燧石的高温啊。要紧的是...

  • 小游戏demo练习

    本周跟着课本的项目,练习了射击外星人功能代码,和记分功能。感觉过程调试的很辛苦,好难过照着写都老出问题,何况独立开...

  • “贪吃蛇🐍”的一生

    前段时间,出于无聊,下载了“贪吃蛇”这个游戏,原本以为这样的小游戏没啥意思,没想到居然上头了。 “贪吃蛇”这个游戏...

  • 新贵 Rust — 贪吃蛇(1)

    今天开始用 Rust 写一个小游戏,大家可能都玩过—贪吃蛇,今天就写个贪吃蛇 snake。首先创建一个项目 sna...

  • 自制简易贪吃蛇

    今天实现一款经典小游戏的实例,贪吃蛇想必大家都有接触过,当然今天实现的细节没有那么全面,只能算是简易版本的小游戏,...

网友评论

  • fcc9195a421b:tujtltt
  • Joe_lisa: 这个在游戏中可能经常会用到,属于2D
  • Joe_lisa:error: /Users/admin/Desktop/TaiJIAnimation-master/核心动画_旋转太极/Objective-C.gitignore: No such file or directory 下面的太极有报错哦
    HelloYeah:额
    忽略文件没找到,我重新上传一下

本文标题:贪吃精灵小游戏demo

本文链接:https://www.haomeiwen.com/subject/bhyclttx.html