Objective-C 自定義漸變色Slider的實(shí)現(xiàn)方法
一、前情概要
系統(tǒng)提供UISlider,但在開發(fā)過程中經(jīng)常需要自定義,本次需求內(nèi)容是實(shí)現(xiàn)一個(gè)擁有漸變色的滑動(dòng)條,且漸變色隨著手指touch的位置不同改變區(qū)域,類似如下
可以使用CAGradientLayer
實(shí)現(xiàn)漸變效果,但是發(fā)現(xiàn)手指滑動(dòng)的快時(shí)會(huì)有不跟手的情況。我們可以重寫左側(cè)有漸變色的UIView的drawRect: 方法
來繪制漸變色
二、具體實(shí)現(xiàn)
左側(cè)的漸變色UIView
HLProgressView.h
@interface HLProgressView : UIView @property (nonatomic, assign) CGSize viewSize; @end
HLProgressView.m
@implementation HLProgressView - (instancetype)initWithFrame:(CGRect)frame{ self = [super initWithFrame:frame]; if (self) { } return self; } - (void)setViewSize:(CGSize)viewSize { _viewSize = viewSize; self.frame = CGRectMake(0, 0, viewSize.width, viewSize.height); // setNeedsDisplay會(huì)自動(dòng)調(diào)用drawRect方法 [self setNeedsDisplay]; } - (void)drawRect:(CGRect)rect { CGSize size = self.bounds.size; // 獲取圖形上下文對(duì)象CGContextRef CGContextRef context = UIGraphicsGetCurrentContext(); // 創(chuàng)建一個(gè)顏色空間 CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB(); // 設(shè)置的顏色 每四個(gè)元素表示一種顏色,值的范圍0~1,分別表示R、G、B、透明度 CGFloat colors[] = { 55.0/255.0, 180.0/255.0, 255.0/255.0, 1.0, 55.0/255.0, 80.0/255.0, 255.0/255.0, 1.0 }; // 漸變的位置信息范圍0~1 0表示開始的位置 1表示結(jié)束的位置 CGFloat gradientLocations[] = {0, 1}; // 漸變的個(gè)數(shù) size_t locationCount = 2; // 創(chuàng)建漸變 CGGradientRef gradient = CGGradientCreateWithColorComponents(colorSpace, colors, gradientLocations, locationCount); // 指定漸變的開始位置和結(jié)束位置 這里設(shè)置完效果是整塊區(qū)域的水平方向的漸變 CGPoint gradientStartPoint = CGPointMake(0, size.height/2); CGPoint gradientEndPoint = CGPointMake(size.width, size.height/2); // 將漸變畫到上下文中,最后一個(gè)參數(shù)表示發(fā)散的方式 CGContextDrawLinearGradient(context, gradient, gradientStartPoint, gradientEndPoint, kCGGradientDrawsBeforeStartLocation); // 釋放內(nèi)存 CGGradientRelease(gradient); CGColorSpaceRelease(colorSpace); } @end
滑動(dòng)條
UICustomSlider.h
@interface UICustomSlider : UIView @end
UICustomSlider.m
@interface UICustomSlider () @property (nonatomic, strong) HLProgressView *progressView; @end @implementation UICustomSlider - (instancetype)initWithFrame:(CGRect)frame { self = [super initWithFrame:frame]; if (self) { self.backgroundColor = [UIColor grayColor]; self.clipsToBounds = YES; //不顯示超過父視圖的內(nèi)容 self.layer.cornerRadius = 8; self.progressView = [[HLProgressView alloc] initWithFrame:CGRectMake(0, 0, 140, 44)]; [self addSubview:self.progressView]; } return self; } - (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event { CGPoint point = [touches.anyObject locationInView:self]; self.progressView.viewSize = CGSizeMake(point.x, self.bounds.size.height); } - (void)touchesMoved:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event { CGPoint point = [touches.anyObject locationInView:self]; self.progressView.viewSize = CGSizeMake(point.x, self.bounds.size.height); } - (void)touchesEnded:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event { CGPoint point = [touches.anyObject locationInView:self]; self.progressView.viewSize = CGSizeMake(point.x, self.bounds.size.height); } @end
調(diào)用滑動(dòng)條
ViewController.m
#import "GradientSlider.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; UICustomSlider *customSlider = [[UICustomSlider alloc] initWithFrame:CGRectMake(20, 100, 280, 44)]; [self.view addSubview:customSlider]; }
到此這篇關(guān)于Objective-C 自定義漸變色Slider的文章就介紹到這了,更多相關(guān)Objective-C 自定義漸變色內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
iOS實(shí)現(xiàn)無(wú)限滑動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)無(wú)限滑動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03iOS中滑動(dòng)控制屏幕亮度和系統(tǒng)音量(附加AVAudioPlayer基本用法和Masonry簡(jiǎn)單使用)
這篇文章主要介紹了iOS中滑動(dòng)控制屏幕亮度和系統(tǒng)音量(附加AVAudioPlayer基本用法和Masonry簡(jiǎn)單使用)的相關(guān)資料,需要的朋友可以參考下2016-12-12iOS中3DTouch預(yù)覽導(dǎo)致TableView滑動(dòng)卡頓問題解決的方法
這篇文章主要給大家介紹了關(guān)于iOS中3DTouch預(yù)覽導(dǎo)致TableView滑動(dòng)卡頓問題解決的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)同樣遇到的朋友們具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起看看吧。2018-03-03iOS9 系統(tǒng)分享調(diào)用之UIActivityViewController
UIActivityViewController類是一個(gè)標(biāo)準(zhǔn)的view controller,通個(gè)使用這個(gè)controller,你的應(yīng)用程序就可以提供各種服務(wù)。本文給大家介紹iOS9 系統(tǒng)分享調(diào)用之UIActivityViewController,感興趣的朋友一起學(xué)習(xí)吧2015-11-11iOS開發(fā)中音頻視頻播放的簡(jiǎn)單實(shí)現(xiàn)方法
視頻音頻是我們?cè)趇os日常開發(fā)中經(jīng)常會(huì)遇到的一個(gè)需求,所以下面這篇文章主要給大家介紹了關(guān)于iOS開發(fā)中音頻視頻播放的簡(jiǎn)單實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10IOS 開發(fā)之自定義按鈕實(shí)現(xiàn)文字圖片位置隨意定制
這篇文章主要介紹了IOS 開發(fā)之自定義按鈕實(shí)現(xiàn)文字圖片位置隨意定制的相關(guān)資料,這里附有實(shí)例代碼及實(shí)現(xiàn)效果圖,需要的朋友可以參考下2016-12-12iOS開發(fā)之TableView實(shí)現(xiàn)完整的分割線詳解
在iOS開發(fā)中, tableView是我們最常用的UI控件之一。所以這篇文章主要給大家詳細(xì)介紹了關(guān)于iOS中的TableView分割線,有需要的朋友們可以參考借鑒,下面來一起看看吧。2016-12-12iOS實(shí)現(xiàn)支持小數(shù)的星星評(píng)分組件實(shí)例代碼
程序中需要打分的功能,在網(wǎng)上找了幾個(gè),都不是很滿意。所以自己動(dòng)手實(shí)現(xiàn)了一個(gè),下面這篇文章主要給大家介紹了關(guān)于利用iOS實(shí)現(xiàn)支持小數(shù)的星星評(píng)分組件的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-08-08