iOS 仿照百度貼吧的灌水加載效果

1.gif

GitHub地址:https://github.com/mengxianliang/XLTieBaLoading
第一步:添加一條曲線
第二步:讓曲線沿x軸移動
第三步:在曲線下部分添加填充色
XLTieBarLoading.h

#import <UIKit/UIKit.h>

@interface XLTieBarLoading : UIView

-(void)show;

-(void)hide;

/**
 * 顯示方法
 */
+(void)showInView:(UIView*)view;

/**
 * 隱藏方法
 */
+(void)hideInView:(UIView*)view;

@end

XLTieBarLoading.m

#import "XLTieBarLoading.h"

@interface XLTieBarLoading ()
{
    CADisplayLink *_disPlayLink;
    /**
     曲線的振幅
     */
    CGFloat _waveAmplitude;
    /**
     曲線角速度
     */
    CGFloat _wavePalstance;
    /**
     曲線初相
     */
    CGFloat _waveX;
    /**
     曲線偏距
     */
    CGFloat _waveY;
    /**
     曲線移動速度
     */
    CGFloat _waveMoveSpeed;
    
    //背景發(fā)暗的圖片 藍(lán)底白字
    UIImageView *_imageView1;
    
    //前面正常顯示的圖片 藍(lán)底白字
    UIImageView *_imageView2;
    
    //動畫的容器
    UIView *_container;
}
@end

@implementation XLTieBarLoading

-(instancetype)initWithFrame:(CGRect)frame
{
    if (self = [super initWithFrame:frame]) {
        [self buildUI];
        [self buildData];
    }
    return self;
}

-(void)buildUI
{
    //畫了個圓
    _container = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 50, 50)];
    _container.center = CGPointMake(self.bounds.size.width/2, self.bounds.size.height/2);
    _container.layer.cornerRadius = _container.bounds.size.width/2.0f;
    _container.layer.masksToBounds = true;
    [self addSubview:_container];
    
    
    
    //底部圖片白底藍(lán)字
    UIImageView *imageView = [[UIImageView alloc] initWithFrame:_container.bounds];
    imageView.image = [UIImage imageNamed:@"1"];
    [_container addSubview:imageView];
    
    //上層圖片藍(lán)底白字
    _imageView1 = [[UIImageView alloc] initWithFrame:_container.bounds];
    _imageView1.image = [UIImage imageNamed:@"2"];
    _imageView1.backgroundColor = [UIColor colorWithRed:51/255.0f green:170/255.0f blue:255/255.0f alpha:1];
    [_container addSubview:_imageView1];
    
    UIView *view = [[UIView alloc] initWithFrame:_imageView1.bounds];
    view.backgroundColor = [UIColor colorWithWhite:0 alpha:0.3];
    [_imageView1 addSubview:view];
    
    
    //下層圖片白底藍(lán)字
    _imageView2 = [[UIImageView alloc] initWithFrame:_container.bounds];
    _imageView2.image = [UIImage imageNamed:@"2"];
    _imageView2.backgroundColor = [UIColor colorWithRed:51/255.0f green:170/255.0f blue:255/255.0f alpha:1];
    [_container addSubview:_imageView2];
}

//初始化數(shù)據(jù)
-(void)buildData
{
    //振幅
    _waveAmplitude = 3;
    //角速度
    _wavePalstance = 0.12;
    //偏距
    _waveY = _container.bounds.size.height;
    //初相
    _waveX = 0;
    //x軸移動速度
    _waveMoveSpeed = 0.15;
    //y軸偏移量
    _waveY = _container.bounds.size.height/2.0f;
    //以屏幕刷新速度為周期刷新曲線的位置
    _disPlayLink = [CADisplayLink displayLinkWithTarget:self selector:@selector(updateWave)];
    [_disPlayLink addToRunLoop:[NSRunLoop mainRunLoop] forMode:NSRunLoopCommonModes];
    _disPlayLink.paused = true;
}

-(void)updateWave
{
    _waveX -= _waveMoveSpeed;
    [self updateWave1];
    [self updateWave2];
}

-(void)updateWave1
{
    //波浪寬度
    CGFloat waterWaveWidth = _container.bounds.size.width;
    //初始化運動路徑
    CGMutablePathRef path = CGPathCreateMutable();
    //設(shè)置起始位置
    CGPathMoveToPoint(path, nil, 0, _waveY);
    //初始化波浪其實Y為偏距
    CGFloat y = _waveY;
    //正弦曲線公式為: y=Asin(ωx+φ)+k;
    for (float x = 0.0f; x <= waterWaveWidth ; x++) {
        y = _waveAmplitude * sin(_wavePalstance * x + _waveX + 1) + _waveY;
        CGPathAddLineToPoint(path, nil, x, y);
    }
    //填充底部顏色
    CGPathAddLineToPoint(path, nil, waterWaveWidth, _container.bounds.size.height);
    CGPathAddLineToPoint(path, nil, 0, _container.bounds.size.height);
    CGPathCloseSubpath(path);
    CAShapeLayer *layer = [CAShapeLayer layer];
    layer.path = path;
    _imageView1.layer.mask = layer;
    CGPathRelease(path);
}

-(void)updateWave2
{
    //波浪寬度
    CGFloat waterWaveWidth = _container.bounds.size.width;
    //初始化運動路徑
    CGMutablePathRef path = CGPathCreateMutable();
    //設(shè)置起始位置
    CGPathMoveToPoint(path, nil, 0, _waveY);
    //初始化波浪其實Y為偏距
    CGFloat y = _waveY;
    //正弦曲線公式為: y=Asin(ωx+φ)+k;
    for (float x = 0.0f; x <= waterWaveWidth ; x++) {
        y = _waveAmplitude * sin(_wavePalstance * x + _waveX) + _waveY;
        CGPathAddLineToPoint(path, nil, x, y);
    }
    //添加終點路徑像樊、填充底部顏色
    CGPathAddLineToPoint(path, nil, waterWaveWidth, _container.bounds.size.height);
    CGPathAddLineToPoint(path, nil, 0, _container.bounds.size.height);
    CGPathCloseSubpath(path);
    CAShapeLayer *layer = [CAShapeLayer layer];
    layer.path = path;
    _imageView2.layer.mask = layer;
    CGPathRelease(path);
}

#pragma mark -
#pragma mark 顯示/隱藏方法

-(void)show{
    _disPlayLink.paused = false;
}

-(void)hide{
    _disPlayLink.paused = true;
}

+(void)showInView:(UIView *)view{
    
    XLTieBarLoading *loading = [[XLTieBarLoading alloc] initWithFrame:view.bounds];
    [view addSubview:loading];
    [loading show];
}

+(void)hideInView:(UIView *)view{
    for (XLTieBarLoading *loading in view.subviews) {
        if ([loading isKindOfClass:[XLTieBarLoading class]]) {
            [loading hide];
            [loading removeFromSuperview];
        }
    }
}

-(void)dealloc
{
    if (_disPlayLink) {
        [_disPlayLink invalidate];
        _disPlayLink = nil;
    }
    
    if (_imageView1) {
        [_imageView1 removeFromSuperview];
        _imageView1 = nil;
    }
    if (_imageView2) {
        [_imageView2 removeFromSuperview];
        _imageView2 = nil;
    }
}

@end

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末锻煌,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子梦染,更是在濱河造成了極大的恐慌,老刑警劉巖饲嗽,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡笑旺,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進(jìn)店門馍资,熙熙樓的掌柜王于貴愁眉苦臉地迎上來筒主,“玉大人,你說我怎么就攤上這事鸟蟹∥诿睿” “怎么了?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵建钥,是天一觀的道長藤韵。 經(jīng)常有香客問我,道長熊经,這世上最難降的妖魔是什么泽艘? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮镐依,結(jié)果婚禮上匹涮,老公的妹妹穿的比我還像新娘。我一直安慰自己槐壳,他們只是感情好焕盟,可當(dāng)我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著宏粤,像睡著了一般脚翘。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上绍哎,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天来农,我揣著相機與錄音,去河邊找鬼崇堰。 笑死沃于,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的海诲。 我是一名探鬼主播繁莹,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼特幔!你這毒婦竟也來了咨演?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤蚯斯,失蹤者是張志新(化名)和其女友劉穎薄风,沒想到半個月后饵较,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡遭赂,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年循诉,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片撇他。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡茄猫,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出困肩,到底是詐尸還是另有隱情募疮,我是刑警寧澤,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布僻弹,位于F島的核電站阿浓,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏蹋绽。R本人自食惡果不足惜芭毙,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望卸耘。 院中可真熱鬧退敦,春花似錦、人聲如沸蚣抗。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽翰铡。三九已至钝域,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間锭魔,已是汗流浹背例证。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留迷捧,地道東北人织咧。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像漠秋,于是被迫代替她去往敵國和親笙蒙。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,614評論 2 353

推薦閱讀更多精彩內(nèi)容