[IOS]对视频、音频播放器添加缓冲进度条

转载 2016年05月31日 11:11:07

[IOS]对视频、音频播放器添加缓冲进度条


[iOS]对视频、音频播放器添加缓冲进度条


Demo地址:http://download.csdn.net/detail/u012881779/8854967

思路说起来很简单:

先拖一个Progress View控件,设置它的Progress Tint和Track Tint;

再拖一个Horizontal Slider覆盖在ProgressView上面,设置它的Min Track Tint 同时设置Max Track Tint为Clear Color(为了透过控件看见背后progressView的背景);

最后分别设置一下各进度的值就OK了。

Min Track Tint(播放进度)、Progress Tint(缓冲进度)、Track Tint(进度条背景)。

[objc] view plain copy
 print?
  1. @interface AVVideoViewController: UIViewController  
  2. @property (weak, nonatomic) IBOutlet UISlider       *mScrubber;     //播放进度  
  3. @property (weak, nonatomic) IBOutlet UIProgressView *cacheProgressV;//缓冲进度  
  4. @end  
  5.   
  6. @implementation AVVideoViewController  
  7.   
  8. - (void)syncScrubber  
  9. {  
  10.     /*播放进度*/  
  11.     CMTime playerDuration = [self playerItemDuration];  
  12.     if (CMTIME_IS_INVALID(playerDuration))   
  13.     {  
  14.         mScrubber.minimumValue = 0.0;  
  15.         [self showStarLabletimeToEndLableTime:0.0 end:0.0];  
  16.         return;  
  17.     }   
  18.       
  19.     double duration = CMTimeGetSeconds(playerDuration);  
  20.     if (isfinite(duration))  
  21.     {  
  22.         float minValue = [self.mScrubber minimumValue];  
  23.         float maxValue = [self.mScrubber maximumValue];  
  24.         double time = CMTimeGetSeconds([self.mPlayer currentTime]);  
  25.         [self showStarLabletimeToEndLableTime:time end:duration];  
  26.         [self.mScrubber setValue:(maxValue - minValue) * time / duration + minValue];  
  27.     }  
  28.   
  29.     /*缓冲进度*/  
  30.     NSTimeInterval timeInterval = [self availableDuration];  
  31.     NSLog(@"Time I nterval:%f",timeInterval);  
  32.     CMTime duration11 = self.mPlayerItem.duration;  
  33.     CGFloat totalDuration = CMTimeGetSeconds(duration11);  
  34.     [_cacheProgressV setProgress:timeInterval / totalDuration animated:YES];  
  35. }  
  36.   
  37. // 计算缓冲进度  
  38. - (NSTimeInterval)availableDuration {  
  39.     NSArray *loadedTimeRanges = [[self.mPlayer currentItem] loadedTimeRanges];  
  40.     CMTimeRange timeRange = [loadedTimeRanges.firstObject CMTimeRangeValue];// 获取缓冲区域  
  41.     float startSeconds = CMTimeGetSeconds(timeRange.start);  
  42.     float durationSeconds = CMTimeGetSeconds(timeRange.duration);  
  43.       
  44.     NSTimeInterval result = startSeconds + durationSeconds;// 计算缓冲总进度  
  45.       
  46.     return result;  
  47. }  
  48.   
  49. @end  
  50.    


示意图:



[IOS]对视频、音频播放器添加缓冲进度条

[IOS]对视频、音频播放器添加缓冲进度条 Demo地址:http://download.csdn.net/detail/u012881779/8854967 思路说起来很简单: 先拖一个Pro...
  • u012881779
  • u012881779
  • 2015年06月30日 17:10
  • 6747

iOS开发从入门到精通-- UIProgressView进度条&UISlider滑动条

UIProgressView进度条&UISlider滑动条: 我们要实现上面图片的效果,在滑动条滑动改变的同时,进度条也跟随着改变。 在 ViewController.h里面声明:#import ...
  • android_it
  • android_it
  • 2016年07月20日 15:04
  • 12007

IOS UIProgressView控件用法(进度条)

初始化一个进度条: - (instancetype)initWithProgressViewStyle:(UIProgressViewStyle)style; 注意:1.用这个方式初始化的进度条系...
  • saw471
  • saw471
  • 2016年06月28日 14:38
  • 2427

[ios]视频音频缓冲进度

  • 2015年06月30日 16:42
  • 645KB
  • 下载

[IOS]对视频、音频播放器添加缓冲进度条

[IOS]对视频、音频播放器添加缓冲进度条 Demo地址:http://download.csdn.net/detail/u012881779/8854967 思路说起来很...
  • wakice
  • wakice
  • 2016年08月31日 12:15
  • 1251

iOS 在线播放进度显示:已经播放的一个颜色,未播放的一个颜色,缓冲的一个颜色

设置代码如下: @property (strong, nonatomic) IBOutlet UISlider *processSlider; //定义一个播放进度...
  • ShenYuanLuo
  • ShenYuanLuo
  • 2015年08月25日 19:45
  • 863

缓冲进度条或加载进度条

缓冲进度条或加载动画进度条
  • u012827205
  • u012827205
  • 2014年09月09日 10:48
  • 3849

iOS 网页进度条 NJKWebViewProgress

APP 访问网页时,经常会见到一个进度条,如图所示: NJKWebViewProgress 可以很好的实现这个效果,使用方法也很简单:...
  • u010551118
  • u010551118
  • 2015年12月13日 16:01
  • 1929

iOS中AVPlayer的在线播放和播放进度条,音量条以及AVPlayer的后台播放

//以下代码用storyboard托控件实现 //导入头文件 #import @interface OnlineViewController() ...
  • wakice
  • wakice
  • 2016年08月31日 12:17
  • 2146

IOS 进度条 progress

@interface MainViewController : UIViewController @property (strong, nonatomic) IBOutlet UIProgressVi...
  • zhbitxhd
  • zhbitxhd
  • 2014年03月13日 14:09
  • 3022
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[IOS]对视频、音频播放器添加缓冲进度条
举报原因:
原因补充:

(最多只允许输入30个字)