打字機效果

typewriteGif.gif

//  TypeWriterLabel.h
 #import <UIKit/UIKit.h>

@interface TypeWriterLabel : UILabel
/** Z
 *  設置單個字打印間隔時間,默認 0.3 秒
 */
@property (nonatomic) NSTimeInterval typewriteTimeInterval;

/** Z
 *  開始打印的位置索引,默認為0丘喻,即從頭開始
 */
@property (nonatomic) int currentIndex;

/** Z
 *  輸入字體的顏色
 */
@property (nonatomic, strong) UIColor *typewriteEffectColor;

/** Z
 *  開始打印
 */
-(void)startTypewrite;

/** Z
 *  定時器
 */
@property (nonatomic, strong) NSTimer  *timer;


@end


 #import "TypeWriterLabel.h"

@implementation TypeWriterLabel

-(void)startTypewrite

{
   
   if (_timer) {
       [_timer invalidate];
       _timer = nil;
   }
   
  _timer = [NSTimer scheduledTimerWithTimeInterval:self.typewriteTimeInterval target:self selector:@selector(outPutWord:) userInfo:nil repeats:YES];

   [_timer fire];
   
}
-(void) outPutWord:(id)atimer

{

   if (self.text.length == self.currentIndex) {
       [atimer invalidate];
       atimer = nil;
   }else{

       self.currentIndex++;
       NSDictionary *dic = @{NSForegroundColorAttributeName: self.typewriteEffectColor};
       NSMutableAttributedString *mutStr = [[NSMutableAttributedString alloc] initWithString:self.text];
       [mutStr addAttributes:dic range:NSMakeRange(0, self.currentIndex)];
       [self setAttributedText:mutStr];

   }

}

@end


-(TypeWriterLabel *)typeLabel{
    if (!_typeLabel) {
        _typeLabel = [[TypeWriterLabel alloc] init];
        [_typeLabel setTypewriteTimeInterval:0.05f];
        [_typeLabel setTypewriteEffectColor:[UIColor grayColor]];
        [_typeLabel setCurrentIndex:0];
        [_typeLabel setBackgroundColor:[UIColor clearColor]];
        [_typeLabel setTextColor:[UIColor clearColor]];
        [_typeLabel setNumberOfLines:0];
    }
    return _typeLabel;
}

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
    
    [self.view setBackgroundColor:[UIColor whiteColor]];
    
    UIImageView *backImageView = [[UIImageView alloc] init];
    [backImageView setFrame:self.view.bounds];
    [backImageView setImage:[UIImage imageNamed:@"1.jpg"]];
    [self.view addSubview:backImageView];
    
    
    [self.typeLabel setFrame:(CGRectMake(20, 30, [UIScreen mainScreen].bounds.size.width - 40, [UIScreen mainScreen].bounds.size.height - 40))];
    [self.view addSubview:self.typeLabel];
    
    [self.typeLabel setText:@"拉塞爾·威斯布魯克(Russell Westbrook)寒亥, 1988年11月12日出生于美國加利福尼亞州長灘(Long Beach, CA)仅颇,美國職業(yè)籃球運動員,司職控球后衛(wèi)烤惊,效力于NBA俄克拉荷馬城雷霆隊茎匠。\n拉塞爾·威斯布魯克于2008年通過選秀進入NBA鼻听,新秀賽季入選最佳新秀陣容第一陣容;6次入選全明星陣容琼开,2015易结、2016連續(xù)兩年獲得全明星賽MVP;2次入選最佳陣容第一陣容柜候,4次入選最佳陣容第二陣容搞动。\n2017年4月10日,雷霆客場106-105戰(zhàn)勝掘金渣刷,拉塞爾·威斯布魯克出場37分鐘鹦肿,得到50分16籃板10助攻,收獲賽季第42次辅柴、職業(yè)生涯常規(guī)賽第79次三雙箩溃,打破了1961-62賽季奧斯卡·羅伯特森創(chuàng)造的單賽季41次三紀錄。同時碌嘀,這是威斯布魯克賽季第3次得分50+的三雙涣旨,成為NBA歷史第一人"];
    [self.typeLabel startTypewrite];
    
}

更新時需要重置currentIndex為0;賦新值股冗;再調(diào)用startTypewrite

附Github地址https://github.com/yuanlove/Typewite-TypewriteLabel

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末霹陡,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌烹棉,老刑警劉巖攒霹,帶你破解...
    沈念sama閱讀 218,451評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異浆洗,居然都是意外死亡催束,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,172評論 3 394
  • 文/潘曉璐 我一進店門伏社,熙熙樓的掌柜王于貴愁眉苦臉地迎上來抠刺,“玉大人,你說我怎么就攤上這事摘昌〗酶叮” “怎么了?”我有些...
    開封第一講書人閱讀 164,782評論 0 354
  • 文/不壞的土叔 我叫張陵第焰,是天一觀的道長。 經(jīng)常有香客問我妨马,道長挺举,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,709評論 1 294
  • 正文 為了忘掉前任烘跺,我火速辦了婚禮湘纵,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘滤淳。我一直安慰自己梧喷,他們只是感情好,可當我...
    茶點故事閱讀 67,733評論 6 392
  • 文/花漫 我一把揭開白布脖咐。 她就那樣靜靜地躺著铺敌,像睡著了一般。 火紅的嫁衣襯著肌膚如雪屁擅。 梳的紋絲不亂的頭發(fā)上偿凭,一...
    開封第一講書人閱讀 51,578評論 1 305
  • 那天,我揣著相機與錄音派歌,去河邊找鬼弯囊。 笑死,一個胖子當著我的面吹牛胶果,可吹牛的內(nèi)容都是我干的匾嘱。 我是一名探鬼主播,決...
    沈念sama閱讀 40,320評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼早抠,長吁一口氣:“原來是場噩夢啊……” “哼霎烙!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,241評論 0 276
  • 序言:老撾萬榮一對情侶失蹤吼过,失蹤者是張志新(化名)和其女友劉穎锐秦,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體盗忱,經(jīng)...
    沈念sama閱讀 45,686評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡酱床,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,878評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了趟佃。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片扇谣。...
    茶點故事閱讀 39,992評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖闲昭,靈堂內(nèi)的尸體忽然破棺而出罐寨,到底是詐尸還是另有隱情,我是刑警寧澤序矩,帶...
    沈念sama閱讀 35,715評論 5 346
  • 正文 年R本政府宣布鸯绿,位于F島的核電站,受9級特大地震影響簸淀,放射性物質(zhì)發(fā)生泄漏瓶蝴。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,336評論 3 330
  • 文/蒙蒙 一租幕、第九天 我趴在偏房一處隱蔽的房頂上張望舷手。 院中可真熱鬧,春花似錦劲绪、人聲如沸男窟。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,912評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽歉眷。三九已至,卻和暖如春祷安,著一層夾襖步出監(jiān)牢的瞬間姥芥,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,040評論 1 270
  • 我被黑心中介騙來泰國打工汇鞭, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留凉唐,地道東北人。 一個月前我還...
    沈念sama閱讀 48,173評論 3 370
  • 正文 我出身青樓霍骄,卻偏偏與公主長得像台囱,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子读整,可洞房花燭夜當晚...
    茶點故事閱讀 44,947評論 2 355

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