iOS實現(xiàn)文字水平無間斷滾動效果
更新時間:2019年08月26日 16:32:12 作者:追夢秋陽
這篇文章主要為大家詳細介紹了iOS實現(xiàn)文字水平無間斷滾動效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
IOS跑馬燈效果,實現(xiàn)文字水平無間斷滾動,示例代碼如下:
ViewController.h
#import <UIKit/UIKit.h> @interface ViewController : UIViewController{ NSTimer *timer; UIScrollView *scrollViewText; } @property (nonatomic ,strong) NSArray *arrData; @end
ViewController.m
// // ViewController.m // 滾動 // #import "ViewController.h" #pragma mark - Class define variable #define K_MAIN_VIEW_SCROLL_HEIGHT 80.0f #define K_MAIN_VIEW_SCROLL_TEXT_TAG 300 #define K_MAIN_VIEW_TEME_INTERVAL 0.35 //計時器間隔時間(單位秒) #define K_MAIN_VIEW_SCROLLER_SPACE 20.0f //每次移動的距離 #define K_MAIN_VIEW_SCROLLER_LABLE_WIDTH 18.0f //單個字符寬度(與你設置的字體大小一致) #define K_MAIN_VIEW_SCROLLER_LABLE_MARGIN 20.0f //前后間隔距離 #define K_MAIN_VIEW_SCROLLER_SLEEP_INTERVAL 1 //停留時間 @interface ViewController () @end @implementation ViewController #pragma mark - Class property @synthesize arrData; - (void)viewDidLoad { [super viewDidLoad]; [self initView]; } - (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning]; // Dispose of any resources that can be recreated. } #pragma mark - Custom method //初始化數(shù)據(jù) -(void) initView{ if (!self.arrData) { self.arrData = @[ @{ @"newsId" :@"201507070942261935", @"newsImg" :@"http://bg.fx678.com/HTMgr/upload/UpFiles/20150707/sy_2015070709395519.jpg", @"newsTitle":@"三大理由歐元任性抗跌,歐元區(qū)峰會將為希臘定調" }, @{ @"newsId" :@"201507070929021220", @"newsImg" :@"http://bg.fx678.com/HTMgr/upload/UpFiles/20150707/sy_2015070709273545.jpg", @"newsTitle" :@"歐盟峰會或現(xiàn)希臘轉機,黃金打響1162保衛(wèi)戰(zhàn)" }, @{ @"newsId" :@"201507070656471857", @"newsImg" :@"http://bg.fx678.com/HTMgr/upload/UpFiles/20150707/2015070706533134.jpg", @"newsTitle" :@"希臘困局歐元不怕,油價服軟暴跌8%" } ]; } //文字滾動 [self initScrollText]; //開啟滾動 [self startScroll]; } //文字滾動初始化 -(void) initScrollText{ //獲取滾動條 scrollViewText = (UIScrollView *)[self.view viewWithTag:K_MAIN_VIEW_SCROLL_TEXT_TAG]; if(!scrollViewText){ scrollViewText = [[UIScrollView alloc] initWithFrame:CGRectMake(0, 80, self.view.frame.size.width, K_MAIN_VIEW_SCROLL_HEIGHT)]; scrollViewText.showsHorizontalScrollIndicator = NO; //隱藏水平滾動條 scrollViewText.showsVerticalScrollIndicator = NO; //隱藏垂直滾動條 scrollViewText.scrollEnabled = NO; //禁用手動滑動 //橫豎屏自適應 scrollViewText.autoresizingMask = UIViewAutoresizingFlexibleWidth; scrollViewText.tag = K_MAIN_VIEW_SCROLL_TEXT_TAG; [scrollViewText setBackgroundColor:[UIColor grayColor]]; //給滾動視圖添加事件 UITapGestureRecognizer *tapGesture = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(scrollerViewClick:)]; [scrollViewText addGestureRecognizer:tapGesture]; //添加到當前視圖 [self.view addSubview:scrollViewText]; }else{ //清除子控件 for (UIView *view in [scrollViewText subviews]) { [view removeFromSuperview]; } } if (self.arrData) { CGFloat offsetX = 0 ,i = 0, h = 30; //設置滾動文字 UIButton *btnText = nil; NSString *strTitle = [[NSString alloc] init]; for (NSDictionary *dicTemp in self.arrData) { strTitle = dicTemp[@"newsTitle"]; btnText = [UIButton buttonWithType:UIButtonTypeCustom]; [btnText setFrame:CGRectMake([self getTitleLeft:i], (K_MAIN_VIEW_SCROLL_HEIGHT - h) / 2, strTitle.length * K_MAIN_VIEW_SCROLLER_LABLE_WIDTH, h)]; [btnText setTitleColor:[UIColor redColor] forState:UIControlStateNormal]; [btnText setTitle:strTitle forState:UIControlStateNormal]; //橫豎屏自適應 btnText.autoresizingMask = UIViewAutoresizingFlexibleWidth; offsetX += btnText.frame.origin.x; //設置為 NO,否則無法響應點擊事件 btnText.userInteractionEnabled = NO; //添加到滾動視圖 [scrollViewText addSubview:btnText]; i++; } //設置滾動區(qū)域大小 [scrollViewText setContentSize:CGSizeMake(offsetX, 0)]; } } #pragma mark - 滾動處理 //開始滾動 -(void) startScroll{ if (!timer) timer = [NSTimer scheduledTimerWithTimeInterval:K_MAIN_VIEW_TEME_INTERVAL target:self selector:@selector(setScrollText) userInfo:nil repeats:YES]; [timer fire]; } //滾動處理 -(void) setScrollText{ [UIView animateWithDuration:K_MAIN_VIEW_TEME_INTERVAL * 2 animations:^{ CGRect rect; CGFloat offsetX = 0.0,width = 0.0; for (UIButton *btnText in scrollViewText.subviews) { rect = btnText.frame; offsetX = rect.origin.x - K_MAIN_VIEW_SCROLLER_SPACE; width = [btnText.titleLabel.text length] * K_MAIN_VIEW_SCROLLER_LABLE_WIDTH; btnText.frame = CGRectMake(offsetX, rect.origin.y, rect.size.width, rect.size.height); NSLog(@"offsetX:%f",offsetX); } if (offsetX < -width){ [UIView setAnimationsEnabled:NO]; [self initScrollText]; }else [UIView setAnimationsEnabled:YES]; }]; } #pragma mark - 動態(tài)獲取左邊位置 -(float) getTitleLeft:(CGFloat) i { float left = i * K_MAIN_VIEW_SCROLLER_LABLE_MARGIN; if (i > 0) { for (int j = 0; j < i; j ++) { left += [[self.arrData objectAtIndex:j][@"newsTitle"] length] * K_MAIN_VIEW_SCROLLER_LABLE_WIDTH; } } return left; } #pragma mark - 新聞點擊事件 -(void)btnNewsClick:(UIButton *) sender{ NSString *strNewsTitle = sender.titleLabel.text; UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"系統(tǒng)提示" message:strNewsTitle delegate:sender cancelButtonTitle:@"確定" otherButtonTitles:@"其他", nil]; [alert show]; } -(void)scrollerViewClick:(UITapGestureRecognizer*)gesture{ CGPoint touchPoint = [gesture locationInView:scrollViewText]; for (UIButton *btn in scrollViewText.subviews) { if ([btn.layer.presentationLayer hitTest:touchPoint]) { [self btnNewsClick:btn]; break; } } } @end
示例源碼下載:文字水平無間斷滾動效果
備注:該開發(fā)工具XCode 版本為 6.4,如無法直接運行,可新建項目將以上文件復制替換即可
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
iOS App設計模式開發(fā)中對interpreter解釋器模式的運用
這篇文章主要介紹了iOS App設計模式開發(fā)中對interpreter解釋器模式的運用,示例為傳統(tǒng)的Objective-C寫成,需要的朋友可以參考下2016-04-04iOS 實現(xiàn)簡單的加載等待動畫示例(思路與實現(xiàn))
本篇文章主要介紹了iOS 實現(xiàn)簡單的加載等待動畫示例(思路與實現(xiàn)),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05iOS開發(fā)中實現(xiàn)hook消息機制的方法探究
這篇文章主要介紹了iOS開發(fā)中實現(xiàn)hook消息機制的方法探究,這里用到了一個Method Swizzling原理,需要的朋友可以參考下2015-10-10一篇文章讓你看懂IOS中的block為何再也不需要WeakSelf弱引用
這篇文章主要給大家介紹了關于IOS中block為何再也不需要WeakSelf弱引用的相關資料,文中通過示例代碼介紹的非常詳細,對各位iOS開發(fā)者們具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2018-01-01IOS self和super詳解實現(xiàn)原理及區(qū)別
這篇文章主要介紹了iOS self和super詳解實現(xiàn)原理及區(qū)別的相關資料,這里不僅說明區(qū)別并介紹實現(xiàn)原理,具有參考價值,需要的朋友可以參考下2016-12-12