当前位置: 首页 > 编程笔记 >

学习iOS全局跑马灯

艾跃
2023-03-14
本文向大家介绍学习iOS全局跑马灯,包括了学习iOS全局跑马灯的使用技巧和注意事项,需要的朋友参考一下

本文实例为大家分享了iOS全局跑马灯制作方法,供大家参考,具体内容如下

思路:

1.创建一个单例

+ (instancetype)shareManager {
 static CCPaomaView *pModel = nil;
 static dispatch_once_t once;
 dispatch_once(&once, ^{
  pModel = [[CCPaomaView alloc]initWithFrame:CGRectMake(0, 0, KScreenWidth, 0.0468 *KScreenHeight)];
 });
 return pModel;
}

2.把接收的数据存在本地的 plist,不适用于大量数据,每次读取第一个数据,读取完成删除整个 plist,再把剩下的重新存进 plist

3.根据动画代理,监听动画执行结束,将动画实例置为 nil

- (void)animationDidStop:(CAAnimation *)anim finished:(BOOL)flag{
 NSLog(@"%@",[self.paomaLabel.layer animationForKey:@"paoMaDeng"]);
 if ([self.paomaLabel.layer animationForKey:@"paoMaDeng"] == anim) {
  //移除第一组数据
  [_array removeObjectAtIndex:0];
  
  //移除整个 plist
  [CCPaomaModel removePaomaPlist];
  
  //重新写入
  [_array writeToFile:[CCPaomaModel filename] atomically:YES];
  
  //动画停止之后,将实例置为 nil
  _pmAniamtion = nil;
  
  //数组为空之后移除跑马灯
  if (_array.count > 0) {
   [self showPaomaView:self.superview];
  }else{
   self.hidden = YES;
   [self removeFromSuperview];
  }
  NSLog(@"%@",self.array);
 }
}

4.判断动画实例是否为空,使得切换界面,跑马灯继续,而不是重新开始

- (void)paomaAniamtion:(CGFloat)count{
 //判断动画实例存不存在,存在继续,不存在即创建
 if (_pmAniamtion == nil) {
  _pmAniamtion = [CABasicAnimation animation];
  _pmAniamtion.keyPath = @"transform.translation.x";
  CGFloat W = CGRectGetWidth(_paomaLabel.bounds);
  _pmAniamtion.fromValue = @(W);
  _pmAniamtion.toValue = @(-W);
  _pmAniamtion.duration = _aniTime;
  _pmAniamtion.repeatCount = count;
  _pmAniamtion.removedOnCompletion = NO;  //动画结束不移除
  _pmAniamtion.fillMode = kCAFillModeForwards; //动画结束会保持结束的状态
  _pmAniamtion.delegate = self;    //设置代理
  [_paomaLabel.layer addAnimation:_pmAniamtion forKey:@"paoMaDeng"];
 }else{
  _pmAniamtion.repeatCount = count;
 }
}

5.切换界面,暂停、恢复动画

#pragma mark -- 界面出现、消失,创建、恢复、暂停动画
- (void)viewWillAppear:(BOOL)animated {
 [_paomaView showPaomaView:self.view];
 [_paomaView resumeAnimation];
}

- (void)viewWillDisappear:(BOOL)animated {
 [_paomaView pauseAniamtion];
}

话不多说,github 见代码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 启用时在配置中添加插件名称 Marquee ,参数如下: 参数 描述 data 数组类型,可添加多个跑马灯。值为object类型 启用时各个data参数如下: 参数 描述 name 名称参数:String loopTime 循环次数,参数:int -1为无限循环。大于1为循环次数。 type 跑马灯类型参数:String ‘text’=文本类型。’image’=图片类型。当类型为文本时字体样式设置

  • 本文向大家介绍iOS 实现跑马灯效果的方法示例,包括了iOS 实现跑马灯效果的方法示例的使用技巧和注意事项,需要的朋友参考一下 在网页开发当中跑马灯是常用到的,用来显示通知等,在游戏开发当中也如此。 首先来看看效果图: 接下来就简单看看这效果是怎么实现的。 实现方法 1、首先我们从这个图片里面能联想到如果实现这个效果必然需要使用到动画,或者还有有用scrollView的思路,这里我是用的动画的方式

  • 本文向大家介绍iOS使用 CABasicAnimation 实现简单的跑马灯(无cpu暴涨),包括了iOS使用 CABasicAnimation 实现简单的跑马灯(无cpu暴涨)的使用技巧和注意事项,需要的朋友参考一下 网上找了几个,但都有cup暴涨的情况发生,于是利用CABasicAnimation 简单的实现一个跑马灯,实现简单,可自己定制 以上就是本文的全部内容,希望对大家的学习有所帮助,也

  • 本文向大家介绍Silverlight实现跑马灯动画,包括了Silverlight实现跑马灯动画的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Silverlight实现跑马灯效果的具体代码,供大家参考,具体内容如下 主要功能有以下几点: 1、使用动画属性驱动图片运动动画 2、图片循环到最后一张后会自动循环 3、当鼠标放到图片时运动的图片会停止,当鼠标离开时暂停的图片会继续运动 4、当

  • 本文向大家介绍Android跑马灯MarqueeView源码解析,包括了Android跑马灯MarqueeView源码解析的使用技巧和注意事项,需要的朋友参考一下 跑马灯效果,大家可以去原作者页面浏览 下面看自定义控件的代码 跑马灯view是继承ViewFlipper,可以看到他的结构体 其实ViewFlipper工作机制很简单,如上图,就是将添加到ViewFlipper中的子View按照顺序定时

  • 本文向大家介绍SpringBoot学习之全局异常处理设置(返回JSON),包括了SpringBoot学习之全局异常处理设置(返回JSON)的使用技巧和注意事项,需要的朋友参考一下 SpringBoot学习——全局异常处理设置(返回JSON) 需求 现在习惯使用ajax的方式发起请求,所以经常需要服务端返回一个json或者字符串。 控制全局的异常处理。 如果在单个方法中使用try,catch把方法包