波浪效果的实现

y = sin(x)


y = 10sin(x)


y = 10sin(0.03x)


y = 10sin(0.03x + 0.5)


y = 10sin(0.03x + 0.5) + 10


y = 10cos(0.03x + 0.5) + 10


双层波 灰色cos 黑色sin

1.创建layer

_shapeLayer= [CAShapeLayer layer];

_shapeLayer.frame=CGRectMake(0,100,375,150);

[self.view.layeraddSublayer:_shapeLayer];

_shapeLayer2= [CAShapeLayer layer];

_shapeLayer2.frame = CGRectMake(0,100,375,150);

[self.view.layer addSublayer:_shapeLayer2];

2.创建定时器

_displayLink = [CADisplayLink displayLinkWithTarget:selfselector:@selector(drawPath)];

[_displayLink addToRunLoop:[NSRunLoopmainRunLoop] forMode:NSRunLoopCommonModes];

3.drawPath方法

static doublei =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越界

}

4.效果图

效果图

玩一个有趣的效果,渐变色:


渐变色

demo已更新代码,这里就不贴代码了

demo

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 做ios 好几年了也没写过什么,我开始写一下这个吧! 首先定义一个waves继承于UIView 的类Waves.h...
    云端飞扬_cb08阅读 3,978评论 0 0
  • 在网易新闻和其他的APP中,大家可能都观察到了在个人中心里面,有一个水波纹一样的动画效果,这个功能还是非常的有用的...
    我在鄱阳湖边阅读 5,641评论 0 6
  • 这是一个网上出过文章的例子,很多人都写过,但是大都是拷贝一个人作者的原文,这篇文章主要的目的是为了细致解析效果实现...
    進无尽阅读 3,508评论 0 0
  • Quartz2D以及drawRect的重绘机制字数1487 阅读21 评论1 喜欢1一、什么是Quartz2D Q...
    PurpleWind阅读 4,314评论 0 3
  • 1:哭泣是一种没人哄就停不下来的泪腺分泌,还伴随没出息的流鼻涕。 2:这世界最伤人的友谊是我把你当最佳损你只当我是...
    你好你好吗阅读 1,769评论 0 0

友情链接更多精彩内容