先上效果图

#import "CHViewController.h"
@interface CHViewController ()
{
    int i;
    int j;
}
@property NSInteger isStart;
@property (nonatomic,retain) NSMutableArray *viewArray;
@property (nonatomic,retain) UIView *neonView;
@property (nonatomic,retain)   NSTimer *timer;

@end

static inline CGRect rectWithScale(CGRect rect,CGFloat scale)
{
    rect.size.width+=scale;
    rect.size.height+=scale;
    return rect;
}

@implementation CHViewController
-(UIColor *)getRandomColor:(NSInteger)max add:(NSInteger)num
{
    CGFloat r,g,b;
    r=arc4random()%max +num;
    g=arc4random()%max +num;
    b=arc4random()%max +num;
    return [UIColor colorWithRed:r/225.0 green:g/225.0 blue:b/225.0 alpha:1.0f];
}

- (void)viewDidLoad
{
    i=0;//视图下标
    j=0;
        _isStart=0;
    ///////////背景色
    UIView *backGround=[[UIView alloc]initWithFrame:self.view.bounds];
    backGround.backgroundColor= [self getRandomColor:31 add:95];
    [self.view addSubview:backGround];
    //////////标题栏视图设置
    UIView *titleView=[[UIView alloc]initWithFrame:CGRectMake(0, 0, 320, 20)];
    titleView.backgroundColor=[UIColor colorWithRed:33/255.0 green:33/255.0  blue:33/255.0  alpha:0.5];
    [backGround addSubview:titleView];
    //////////按钮设置
   UIButton *button= [UIButton buttonWithType:UIButtonTypeRoundedRect];
    button.frame=CGRectMake(20, backGround.bounds.size.height-130, 280, 40);
    [button setTitle:@"Start" forState:UIControlStateNormal];
    [button setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
    button.backgroundColor=[UIColor whiteColor];
    [backGround addSubview:button];
    [button addTarget:self action:@selector(onClick:) forControlEvents:UIControlEventTouchUpInside];
    
    ///////////////霓虹灯框视图设置
    _neonView=[[UIView alloc]initWithFrame:CGRectMake(50, 60, 220, 220)];
    _neonView.backgroundColor=[UIColor whiteColor];
    [backGround addSubview:_neonView];
 
    //////////////zoom视图入数组
    _viewArray=[[NSMutableArray alloc]init];
    for (int index=0; index<1000; index++) {
        UIView *view=[[UIView alloc]initWithFrame:CGRectMake(0,0,5,5)];
          CGPoint point=CGPointMake(CGRectGetMidX(_neonView.bounds), CGRectGetMidY(_neonView.bounds));
        view.center=point;
            view.bounds=rectWithScale(view.bounds, 4.3f);
            view.backgroundColor=[self getRandomColor:256 add:0];
        [_viewArray addObject:view];
    }
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
}

-(void)onClick:(UIButton *)button
{
    i=0;

if (_isStart==0) {
_timer=[NSTimer scheduledTimerWithTimeInterval:0.1 target:self selector:@selector(showTime:) userInfo:nil repeats:YES];
        _isStart=1;
        [button setTitle:@"Stop" forState:UIControlStateNormal];
        
    }
    else
    {
        _isStart=0;
        [button setTitle:@"Start" forState:UIControlStateNormal];
        [_timer invalidate];
    }
    }

-(void)showTime:(NSTimer *)timer
{
 
   for (j=0; j<i; j++) {
     if (((UIView*)_viewArray[j]).bounds.size.height>=CGRectGetHeight(_neonView.bounds)) {
        ((UIView*)_viewArray[j]).bounds=CGRectMake(0,0,5,5);
        ((UIView*)_viewArray[j]).center=CGPointMake(CGRectGetMidX(_neonView.bounds), CGRectGetMidY(_neonView.bounds));
        [((UIView*)_viewArray[j]) removeFromSuperview];
         //[_neonView addSubview:_viewArray[j]];
        
    }
        ((UIView*)_viewArray[j]).bounds=rectWithScale(((UIView*)_viewArray[j]).bounds, 5.0f);
       // ((UIView*)_viewArray[j]).backgroundColor=[self getRandomColor:256 add:0];
        if (i<1000)
       [_neonView addSubview:_viewArray[j]];
      
   }
    if (i<1000) {
         i++;
    }
    
}

- (void)didReceiveMemoryWarning
{
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
  /*  UIView *view=    }*/

}

@end

IOS 作业项目(3) 霓虹灯效果的更多相关文章

  1. IOS 作业项目(4)步步完成 画图 程序(中)

    一,承接上文,继续本文  [UIButton buttonWithType:UIButtonTypeRoundedRect]; 如此声明的按钮才会有点击闪动的效果!如果直接frame方式声明就不会有. ...

  2. IOS 作业项目(2) 画图(保存,撤销,笔粗细设定功能)

    先上效果图

  3. IOS 作业项目(1) 关灯游戏 (百行代码搞定)

    1,准备工作,既然要开关灯,就需要确定灯的灯的颜色状态 首先想到的是扩展UIColor

  4. IOS 作业项目 TableView两个section中cell置顶功能实现

    点击cell会置顶,其他的下移

  5. IOS 作业项目(4)步步完成 画图 程序(问题处理)终结

    一,解决换色程序崩溃问题 程序崩溃是因为颜色的内存被释放,添加如下类的内容即可 @implementation TuyaPath - (id)init { self = [super init]; i ...

  6. IOS 作业项目(4)步步完成 画图 程序(剧终)

    // //  CHViewController.m //  SuperDrawingSample // //  Created by JaikenLI on 13-11-21. //  Copyrig ...

  7. IOS 作业项目(4)步步完成 画图 程序(中续)

    一,程序布局整理 前言://1,程序启动//2,程序流程框架//3,程序界面一致//4,程序界面功能, //这里只做页面的固定功能, //在首次创建界面时,我们会指定好固定事件触发前的固定方法 //至 ...

  8. IOS 作业项目(4)步步完成 画图 程序(上)

    先上流程图

  9. GitHub Android 最火开源项目Top20 GitHub 上的开源项目不胜枚举,越来越多的开源项目正在迁移到GitHub平台上。基于不要重复造轮子的原则,了解当下比较流行的Android与iOS开源项目很是必要。利用这些项目,有时能够让你达到事半功倍的效果。

    1. ActionBarSherlock(推荐) ActionBarSherlock应该算得上是GitHub上最火的Android开源项目了,它是一个独立的库,通过一个API和主题,开发者就可以很方便 ...

随机推荐

  1. MATLAB画图

    画图代码 clear % http://www.peteryu.ca/tutorials/matlab/visualize_decision_boundaries % load RankData % ...

  2. 转:Nginx+Apache环境的安装与配置

    转:http://www.server110.com/nginx/201404/8817.html 我们依然尽可能采用yum来安装我们需要的软件,由系统官方维护的软件,其安全性和稳定性都值得信赖,并且 ...

  3. java邮件

    我们用过很多邮件,qq,163,网易等. 一.发送邮件需要遵循smtp协议,接收邮件需要遵循pop3协议 二.发邮件的过程 假设用qq邮件 写邮件-->点 “发送” --> qq邮件服务器 ...

  4. Matrix-Tree定理

    感觉又学到了一个利器! 感谢Vfleaking神犇,传送门 http://vfleaking.blog.163.com/blog/static/1748076342013112523651955/   ...

  5. S1:函数上下文

    函数的上下文是可以变化的,因此,函数内的this也是可以变化的,函数可以作为一个对象的方法,也可以同时作为另一个对象的方法,总之,函数本身是独立的.可以通过Function对象上的call或者appl ...

  6. HTML内容整理

    <html> <head> <meta http-equiv="Content-Type" content="text/html; char ...

  7. IBatis.Net 表连接查询(五)

    IBatis.Net之多表查询: 一.定制实际对应类的方式 首先配置多表的测试数据库,IBatis.Net之Oracle表连接查询配置: 首先新建两张表如下: 为两张表建立外键: ALTER TABL ...

  8. SelectedRows.CurrentRowSelected 和 DeleteItem

    procedure TBMListEh.SetCurrentRowSelected(Value: Boolean); var Index: Integer; Current: TUniBookmark ...

  9. 2、IValueConverter应用

    1.C#代码如下: public class logotoimgConverter:IValueConverter { //将logo转换为URI public object Convert(obje ...

  10. Ohlàlà

    Chap 1数数字 un 1 deux 2 trois 3 quatre 4 cinq 5 six 6 sept 7 huit 8 neuf 9 dix 10   Chap 2 讲地名 Paris 巴 ...