iOS实现波浪效果

作者: iOS猿_员 | 来源:发表于2018-10-27 12:48 被阅读111次

这篇文章主要为大家详细介绍了iOS实现波浪效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了iOS实现波浪效果的具体代码,供大家参考,具体内容如下


效果图.gif

代码:

@interface ViewController () 
@property (strong, nonatomic) CADisplayLink *displayLink;
@property (strong, nonatomic) CAShapeLayer *shapeLayer;
@property (strong, nonatomic) UIBezierPath *path;
@property (strong, nonatomic) CAShapeLayer *shapeLayer2;
@property (strong, nonatomic) UIBezierPath *path2;
@end
 
@implementation ViewController
 
- (void)viewDidLoad {
 [super viewDidLoad]; 
 
 _shapeLayer = [CAShapeLayer layer];
 _shapeLayer.frame = CGRectMake(0, 100, 375, 150);
 [self.view.layer addSublayer:_shapeLayer];
  
 
 _shapeLayer2 = [CAShapeLayer layer];
 _shapeLayer2.frame = CGRectMake(0, 100, 375, 150);
 [self.view.layer addSublayer:_shapeLayer2];
 
 
 _shapeLayer.fillColor = [[UIColor yellowColor] colorWithAlphaComponent:0.3].CGColor;
 _shapeLayer2.fillColor = [[UIColor blueColor] colorWithAlphaComponent:0.3].CGColor; 
 
 _displayLink = [CADisplayLink displayLinkWithTarget:self selector:@selector(drawPath)];
 [_displayLink addToRunLoop:[NSRunLoop mainRunLoop] forMode:NSRunLoopCommonModes]; 
 
} 
 
- (void)drawPath {
 
 static double i = 0;
  
 CGFloat A = 10.f;//A振幅
 CGFloat k = 0;//y轴偏移
 CGFloat ω = 0.03;//角速度ω变大,则波形在X轴上收缩(波形变紧密);角速度ω变小,则波形在X轴上延展(波形变稀疏)。不等于0
 CGFloat φ = 0 + i;//初相,x=0时的相位;反映在坐标系上则为图像的左右移动。
 
 //y=Asin(ωx+φ)+k 
 
 _path = [UIBezierPath bezierPath];
 _path2 = [UIBezierPath bezierPath]; 
 
 [_path moveToPoint:CGPointZero];
 [_path2 moveToPoint:CGPointZero];
 for (int i = 0; i < 376; i ++) {
 
  CGFloat x = i;
 
  CGFloat y = A * sin(ω*x+φ)+k;
  CGFloat y2 = A * cos(ω*x+φ)+k;
  [_path addLineToPoint:CGPointMake(x, y)];
  [_path2 addLineToPoint:CGPointMake(x, y2)];
 
 }
 [_path addLineToPoint:CGPointMake(375, -100)];
 [_path addLineToPoint:CGPointMake(0, -100)];
 _path.lineWidth = 1;
 _shapeLayer.path = _path.CGPath; 
 
 [_path2 addLineToPoint:CGPointMake(375, -100)];
 [_path2 addLineToPoint:CGPointMake(0, -100)];
 _path2.lineWidth = 1;
 
  _shapeLayer2.path = _path2.CGPath;
 
  
 
 i += 0.1;
 
 if (i > M_PI * 2) {
 
  i = 0;//防止i越界
 
 }
 
}

以上就是这篇文章的全部内容了,希望本文的内容对大家具有一定的参考学习价值,如果有疑问大家可以进入小编交流群:624212887,一起交流学习,并分享各类面试书籍,面试题,谢谢大家的支持

相关文章

  • iOS实现波浪效果

    iOS实现波浪效果

  • iOS实现波浪效果

    这篇文章主要为大家详细介绍了iOS实现波浪效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 本文实例为大家分...

  • IOS波浪效果的实现

    做ios 好几年了也没写过什么,我开始写一下这个吧! 首先定义一个waves继承于UIView 的类Waves.h...

  • iOS波浪效果实现

    为了使界面看起来高大上,很多app都会加入各种各样的动态效果。本篇文章就简单谈谈波浪效果的实现,效果如下所示: 实...

  • iOS波浪效果超简单实现

    先上 GitHub地址 GLWaveView 介绍 一个自带波形动画的View, 可以添加多层波浪且方便自定义, ...

  • iOS波浪效果-OpenGL实现篇

    本文所用的代码在https://github.com/SquarePants1991/WaveEffect 工作需...

  • iOS- 波浪效果简单实现

    //只跟相位有关 (void)creat4{ CGFloatW =CGRectGetWidth(self.view...

  • iOS 波浪效果

    效果波浪效果 WaveView.h WaveView.m 实现

  • iOS 圆形水波浪效果实现

    水波浪效果如下 最近项目中用到一个小的波浪动画,查阅了一些资料如下:网上参考的一些效果CDNS上的原理 主要实现方...

  • 波浪效果的实现

    1.创建layer _shapeLayer= [CAShapeLayer layer];_shapeLayer.f...

网友评论

    本文标题:iOS实现波浪效果

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