七彩霓虹灯 制作

22 篇文章 0 订阅

在ui学习,用简单地uiView和视图控制器制作的霓虹灯效果,在这个过程中要学会使用定时器NSTimer的开启与关闭,这个是实现动态效果的关键一步,在使用时可以查看API文档查看,也可以上网查询;

初始化
+ (NSTimer *)timerWithTimeInterval:(NSTimeInterval)ti target:(id)aTarget selector:(SEL)aSelector userInfo:(id)userInfo repeats:(BOOL)yesOrNo;

  • (NSTimer *)scheduledTimerWithTimeInterval:(NSTimeInterval)ti target:(id)aTarget selector:(SEL)aSelector userInfo:(id)userInfo repeats:(BOOL)yesOrNo;
 //开启定时器
   [_timer setFireDate:[NSDate distantPast]];
  //暂停定时器
   [_timer invalidate];

这里timer的内存并没有释放,如果释放了可能造成程序崩溃,这是我现在没有解决的

效果图

(http://img.blog.csdn.net/20151121174843569)
- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    //布局子视图
    for (int i = 0; i < 10; i ++) {
        UIView *view = [[UIView alloc] initWithFrame:CGRectMake ( 15 +15*(i + 1), 15 * (i +1), 300 - i * 30, 600 -i *30 )] ;
        [self.view addSubview:view];
        view.backgroundColor = [UIColor colorWithRed:KColorKey green:KColorKey blue:KColorKey alpha:1.0];
        view.tag = 100 + i;
        [view release];



    }
    //添加按钮

    UIButton *btn = [UIButton buttonWithType:UIButtonTypeSystem];
        btn.frame = CGRectMake(80, 620, 80, 40);
        btn.backgroundColor = [UIColor greenColor];
        [btn setTitle:@"开始" forState:UIControlStateNormal];
    [btn addTarget:self action:@selector(begin:) forControlEvents:UIControlEventTouchUpInside];
        [self.view addSubview:btn];

    UIButton *btn1 = [UIButton buttonWithType:UIButtonTypeSystem];
    btn1.frame = CGRectMake(180, 620, 80, 40);
    btn1.backgroundColor = [UIColor greenColor];
    [btn1 setTitle:@"取消" forState:UIControlStateNormal];
    [btn1 addTarget:self action:@selector(stop:) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:btn1];




   }




//开始事件
- (void)begin: (UIButton *)btn {
     //添加定时器
    _timer = [NSTimer scheduledTimerWithTimeInterval:0.5 target:self selector:@selector(fromout) userInfo:nil repeats:YES];
    //开启定时器
   [_timer setFireDate:[NSDate distantPast]];




}
//实现事件
//从里向外
- (void)fromout {
    UIColor *tem = [self.view viewWithTag:100].backgroundColor;
    for (int i = 100; i < 110; i ++) {
        [self.view viewWithTag:i].backgroundColor = [self.view viewWithTag:i+ 1].backgroundColor;
    }

    [self.view viewWithTag:100 + 9].backgroundColor = tem;
    //从外向里
    //    UIColor *temp = [self.view viewWithTag:100 + 9].backgroundColor;
    //    for (int i = 100 + 9; i >= 100; i--) {
    //        [self.view viewWithTag:i].backgroundColor = [self.view viewWithTag:i-1].backgroundColor;
    //    }
    //    [self.view viewWithTag:100].backgroundColor = temp;


}
- (void)stop: (UIButton*) btn {
   //暂停定时器
   [_timer invalidate];
   }
@end
### 回答1: 要制作七彩灯,可以使用HTML中的CSS和JavaScript来实现。首先,我们需要创建一个HTML页面,并引入相应的CSS和JavaScript文件。 在HTML中,我们可以使用`<div>`元素来表示灯泡,并给每个灯泡添加一个独特的标识id。例如,可以创建一个`<div>`元素,并给它一个id为`"light1"`。 接下来,在CSS文件中,我们可以为每个灯泡添加样式。通过使用不同的背景颜色和动画效果,每个灯泡都可以呈现出七彩的效果。例如,我们可以为id为`"light1"`的灯泡设置背景色为红色,并添加一个闪烁的动画效果。 在JavaScript中,我们可以使用`setTimeout`函数来控制灯泡的闪烁效果。通过设置不同的时间间隔和颜色,每个灯泡都可以按照一定的顺序进行闪烁。例如,我们可以使用`setTimeout`函数来设置id为`"light1"`的灯泡在1000毫秒后变为蓝色,在2000毫秒后变为绿色,然后重复这个过程。 最后,我们只需要在HTML文件中调用JavaScript函数来启动闪烁效果。例如,可以在`<body>`标签内添加一个`<script>`标签,并在其中调用一个函数,这个函数将启动灯泡的闪烁效果。 综上所述,通过使用HTML的`<div>`元素, CSS样式和JavaScript控制,我们可以制作出一个七彩灯。每个灯泡都可以按照一定的顺序和时间间隔闪烁不同的颜色,从而呈现出七彩的效果。 ### 回答2: 要使用HTML代码制作七彩灯,我们可以通过CSS的背景颜色属性和JavaScript的计时器来实现。 首先,在HTML文件中创建一个div元素,作为七彩灯的容器。给这个div添加一个唯一的id,以便在JavaScript中能够通过id选择器来操作它。 然后,在CSS文件中给这个div元素添加样式,设置它的宽度、高度,以及背景颜色为黑色。同时,设置div的position属性为relative,以便在JavaScript中能够修改它的位置。 接下来,在JavaScript文件中创建一个函数,命名为colorfulLight()。在函数内部,使用定时器函数setInterval()来不断执行一个匿名函数。 在匿名函数内部,先获取前面创建的div元素,然后生成一个随机的RGB颜色值,并将它设为div元素的背景颜色。可以使用Math.random()函数生成0到255的随机数,并将其转换为十六进制颜色码。 最后,在页面加载完成后,调用colorfulLight()函数,以开始让七彩灯闪烁。 以下是一个示例的HTML代码: ```html <!DOCTYPE html> <html> <head> <style> #colorful-light { width: 100px; height: 100px; background-color: black; position: relative; } </style> </head> <body> <div id="colorful-light"></div> <script> function colorfulLight() { setInterval(function() { var div = document.getElementById("colorful-light"); var randomColor = '#' + Math.floor(Math.random() * 16777215).toString(16); div.style.backgroundColor = randomColor; }, 1000); } window.onload = function() { colorfulLight(); }; </script> </body> </html> ``` 上述代码会使七彩灯每隔1秒钟闪烁一次,每次闪烁都会在div元素的背景颜色中随机生成一个RGB颜色。可以根据需要调整闪烁的频率或div元素的大小。 ### 回答3: 用 HTML 代码制作七彩灯可以使用 CSS 的动画和渐变效果来实现。 首先,在 HTML 页面中创建一个 div 元素,设置宽度和高度,并且给定一个具体的 id 名称,例如 `<div id="color-light"></div>`。 接下来,在 CSS 样式表中定义该 div 元素的样式。给定宽度和高度之后,使用 CSS 的动画属性 `animation`,指定一个动画名称和持续时间,例如将动画名称设为 `colorful-light`,持续时间设为 2 秒。 然后,创建关键帧动画 `@keyframes colorful-light`,指定帧的样式。每一帧的样式可以使用 CSS 的渐变效果来生成不同的颜色。可以使用 `background` 属性来指定不同的颜色,使用 `stop` 属性来控制颜色的位置。 最后,在 CSS 样式表中调用关键帧动画 `animation`,指定动画名称和持续时间。 具体的代码如下所示: HTML 代码: ``` <div id="color-light"></div> ``` CSS 代码: ``` #color-light { width: 100px; height: 100px; animation: colorful-light 2s infinite; } @keyframes colorful-light { 0% { background: red; } 25% { background: orange; } 50% { background: yellow; } 75% { background: green; } 100% { background: blue; } } ``` 这样,在浏览器中运行该 HTML 页面,就可以看到一个七彩灯闪烁的效果。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值