iOS之关灯小游戏

原创 2015年11月21日 12:04:04

先创建一对ViewController文件,用来编写开灯关灯的实现
LightViewController.h
LightViewController.m

在.h文件里定义两个属性,一个line:灯的行数,col:灯的列数
@property(assign, nonatomic)NSInteger line;
@property(assign, nonatomic)NSInteger col;

封装一个铺灯界面的方法

-(void)makeLightGame:(NSInteger)line col:(NSInteger)col{
    _line = line;
    _col = col;
    NSInteger x = (self.view.frame.size.width - 10)/col;
    for (NSInteger i = 0; i < _line; i++) {
        for (NSInteger j = 0; j < _col; j++) {
            UIButton *but = [[UIButton alloc] initWithFrame:CGRectMake(10 + x*j, 30 + x*i, x - 1 , x-1)];
            but.backgroundColor = [UIColor colorWithRed:0.804 green:0.243 blue:0.643 alpha:1];

            //每个灯都是一个Button,给每个Button添加了点击事件
            [but addTarget:self action:@selector(but:) forControlEvents:UIControlEventTouchUpInside];
            //设置每个button的tag值,避免出现列如:点击第二排第一个灯的时候,第一排最后一个灯也被关掉。每排假装多了一个灯(button)
            but.tag = 1 + j + (_col+1)*i;
            [self.view addSubview:but];
        }
    }
}

实现点击事件方法
方法说明:点击了一个灯(button)之后执行下面的点击事件,并把点击的那个button作为参数传了进来,根据tag值找到上下左右四个灯,并且根据当时各个灯的状态进行开关(changeColor方法:开的话就置成关,关就置成开)。

-(void)but:(UIButton *)but{
//被点击的灯

 //下面的灯
    UIButton *up = (UIButton *)[self.view viewWithTag:but.tag - _col - 1];
    [self changeColor:up];

 //上面的灯
    UIButton *down = (UIButton *)[self.view viewWithTag:but.tag + _col + 1];
    [self changeColor:down];

    //左边的灯,由于button的tag值是从1开始的,要避免遇到tag=0的那个button(tag=0默认为当前父类View,无法改变)。判断如果被点击的是第一排第一个灯就不检测左边的灯(因为左边的灯不存在)
    UIButton *left = (UIButton *)[self.view viewWithTag:but.tag - 1];
    if (left.tag != 0) {
        [self changeColor:left];
    }

    //右边的灯
    UIButton *right = (UIButton *)[self.view viewWithTag:but.tag + 1];
    [self changeColor:right];
}

检测灯的状态进行开关操作方法—changeColor

-(void)changeColor:(UIButton *)but{
//判断按钮but是否是被点击过,开始都为开灯,如果被点击过那么此时应该是关灯状态,如果被点击过,开灯。
    if (but.isSelected) {
        but.backgroundColor = [UIColor colorWithRed:0.804 green:0.243 blue:0.643 alpha:1];
    }else{
        but.backgroundColor = [UIColor blackColor];
    }
    //被点击设置成没被点击(开灯状态),没被点击设置成被点击(关灯状态)
    but.selected = !but.selected;
}

相关文章推荐

iOS关灯小游戏

  • 2013年05月09日 11:15
  • 37KB
  • 下载

IOS简单关灯小游戏

在AppDelegate.m文件中添加视图控制器 #import "AppDelegate.h" #import "RootViewController.h" @implementation AppD...

iOS中自定义UIImageView用TargetAction模式实现关灯小游戏

首先第一个问题:什么是TargetAciton模式?TargetAction模式类似于UIButton,简单来说就是将UIImageView利用TargetAction模式捆绑个事件,实现和UIBut...

关灯游戏ios小游戏

  • 2014年01月10日 12:26
  • 68KB
  • 下载

开关灯js小游戏

html代码 div{border:1px solid #FFFFCC;margin: 0 auto;margin-top: 40px;} span{float:l...

UI 代码 关灯小游戏 demo

光灯小游戏 知识点: tag值得运用 思路: 1.新建一个UIViewController视图控制器文件 (用来实现事件) 2.新建一个UIView 类文件(LightView) 用于对整个页面做...
  • MHTios
  • MHTios
  • 2014年09月01日 10:15
  • 1274

关灯小游戏

  • 2004年07月07日 00:00
  • 8KB
  • 下载

关灯小游戏

  • 2006年02月23日 09:05
  • 4KB
  • 下载

IOS开发入门基本知识——UIButton生成的关灯游戏(tag值的灵活运用)

关灯游戏,灯分为 两种状态,绿和红,当被点击的时候,自己和周围的等变为相反的颜色,游戏以全部呈现为另外一种颜色为赢 实现思路,先贴button,button很多,在帖的时候肯...

关灯小游戏

  • 2016年12月13日 21:36
  • 2.62MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:iOS之关灯小游戏
举报原因:
原因补充:

(最多只允许输入30个字)