欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS中的UISlider滑塊組件用法總結(jié)

 更新時間:2016年06月09日 09:27:32   作者:ian  
不僅是滑動開關(guān),UISlider組件也是常用的進度條制作工具,這里我們就一起來看一下iOS中的UISlider滑塊組件用法總結(jié),需要的朋友可以參考下

PC上的滑塊是很丑陋的,因為我們只能通過鼠標去拖動他。不過當Jobs把它移植到IOS上時一切變得酷起來,因為我們可以通過手指去拖動它,這種感覺是很妙的。
滑塊為用戶提供了一種可見的做范圍調(diào)整的方法,用戶可以通過拖動一個滑動條改變它的值,并且可以對其配置以合適不同值域。你可以設(shè)置滑塊值的范圍,也可以在兩端加上圖片,以及進行各種調(diào)整讓它更美觀?;瑝K非常適合用于表示在很大范圍(但不精確)的數(shù)值中進行選擇,比如音量設(shè)置、靈敏度控制等諸如此類的用途。
一、創(chuàng)建
滑塊是一個標準的UIControl。我們可以通過代碼創(chuàng)建,如同開關(guān)(UISwitch)的寬與高都會被忽略一樣滑塊的高也會被忽略(但是寬度不會):

復(fù)制代碼 代碼如下:

UISlider* mySlider = [ [ UISlider alloc ] initWithFrame:CGRectMake(20.0,10.0,200.0,0.0) ];//高度設(shè)為0就好   

二、設(shè)定范圍與默認值
創(chuàng)建完畢的同時我們要設(shè)置好滑塊的范圍,如果你沒有設(shè)置,那么會使用默認的 0.0 到 1.0 之間的值。UISlider提供了兩個屬性來設(shè)置范圍:mininumValue 和 maxinumValue:
復(fù)制代碼 代碼如下:

mySlider.mininumValue = 0.0;//下限 
mySlider.maxinumValue = 50.0;//上限 

同時你也可以為滑塊設(shè)定一個默認值:
復(fù)制代碼 代碼如下:

mySlider.value = 22.0; 

三、兩端添加圖片
滑塊可以在任何一段顯示圖像。添加圖像后會導(dǎo)致滑動條縮短,所以記得要記得在創(chuàng)建的時候增加滑塊的寬度來適應(yīng)圖像。
復(fù)制代碼 代碼如下:

[ mySlider setMininumTrackImage: [ UIImage applicationImageNamed:@"min.png" ] forState: UIControlStateNormal ]; 
[ mySlider setMaxinumTrackImage: [ UIImage applicationImageNamed:@"max.png" ] forState: UIControlStateNormal ]; 

你可以根據(jù)滑塊的各種不同狀態(tài)顯示不同的圖像。下面是可用狀態(tài):
復(fù)制代碼 代碼如下:

UIControlStateNormal
UIControlStateHighlighted
UIControlStateDisabled
UIControlStateDisabled
UIControlStateSelected

四、顯示控件
復(fù)制代碼 代碼如下:

[ parentView addSubview:myslider ];//添加到父視圖 

或 
復(fù)制代碼 代碼如下:

[ self.navigationItem.titleView addSubview:myslider ];//添加到導(dǎo)航欄

五、讀取控件值
復(fù)制代碼 代碼如下:

float value = mySlider.value; 

六、通知
要想在滑塊值改變時收到通知,可以用UIControl類的addTarget方法為UIControlEventValueChanged事件添加一個動作。
復(fù)制代碼 代碼如下:

[ mySlider addTarget:self action:@selector(sliderValueChanged:) forControlEventValueChanged ]; 

 只要滑塊停放(注意是停放,如果要在拖動中也觸發(fā),請看后文)到新的位置,你的動作方法就會被調(diào)用:
復(fù)制代碼 代碼如下:

- (void) sliderValueChanged:(id)sender{ 
        UISlider* control = (UISlider*)sender; 
        if(control == mySlider){ 
                  float value = control.value; 
                   /* 添加自己的處理代碼 */ 
         } 


如果要在拖動中也觸發(fā),需要設(shè)置滑塊的 continuos 屬性:
復(fù)制代碼 代碼如下:

mySlider.continuous = YES ; 

這個通知最簡單的一個實例就是實時顯示滑塊的值,很奇怪的蘋果顯示滑塊的值是一個私有的API(setShowValue),私有就私有,大不了我不用就是。我們可以用一個UILabel來顯示值,在每次觸發(fā)上面的方法時改變label的值,不就可以實時顯示了嗎?當然我們可以做的不僅僅是這個,還有更多的 cool 事情可以去實現(xiàn),就看你的手段與想象力了。

七、UISlider兩邊有空隙的解決方法
之前做過一個播放器,音量條兩邊有空隙。在去新浪面試的時候,面試官提到了這個知識點。我在stackoverflow上爬了好久終于找到了方法,分享給iOS初學者。
重寫UISlider的這個方法

復(fù)制代碼 代碼如下:

- (CGRect)thumbRectForBounds:(CGRect)bounds trackRect:(CGRect)rect value:(float)value
{
    rect.origin.x = rect.origin.x - 10 ;
    rect.size.width = rect.size.width +20;
    return CGRectInset ([super thumbRectForBounds:bounds trackRect:rect value:value], 10 , 10);
}

當然UISlider還有這么幾個方法可以重寫
復(fù)制代碼 代碼如下:

-(CGRect)trackRectForBounds:(CGRect)bounds
{
    bounds.origin.x=15;
    bounds.origin.y=bounds.size.height/3;
    bounds.size.height=bounds.size.height/5;
    bounds.size.width=bounds.size.width-30;
    return bounds;
}
- (CGRect)minimumValueImageRectForBounds:(CGRect)bounds;
- (CGRect)maximumValueImageRectForBounds:(CGRect)bounds;

您可能感興趣的文章:

相關(guān)文章

最新評論