Iphone开发(五)用滑块slider来调节控件透明度

控件UISlider称之为滑块,用户可以进行拖拽,可以通过拖拽来调节一些信息,比如音量,背光亮度等,我们今天用滑块来调节一下控件的透明度。

首先去网上找一个iphone壁纸作为我们这个demo的背景图片,下载下来后将其拖到应用中,,然后在右下角media库中会找到这个图片,然后如下图将其拖拽到xib文件上,并按图中标注的进行设置,分别是铺展开,另一个是取消用户响应。取消用户响应我们稍候会作解释,现在将这幅图片设为背景后我们往上面放上两个控件,额,就放一个TextField和一个button吧,然后再拖上一个Slider和一个label用来表示当前透明度。将label的背景设为白色了,不然看不清楚。

 

 

 

这时我们画好界面后,就开始在代码中生成对应的输出口来绑定控件了,在创建xib文件和viewController文件绑定的输出口时,可分别双击xib文件和viewController.h文件打开两个独立窗口,然后在xib文件的窗口中按着control键单击控件并拖拽到viewController.h文件中的声明部分,这样便会弹出一个窗口让你设置输出口的名字,设置好后会自动生在输出口并将其与xib文件中的控件绑定,如下:

 

这时我们就要写IBAction方法来捕捉滑块的变化了,我们命名为sliderChanged,参数为自动生成的sender,表示该slider.我们将各个控件透明度的变化也写到这个方法里,该方法会捕捉slider值的变化,然后调节各个控件的透明度。另外我们还要再写一个方法用来在文本框编辑时点击别的地方来关闭键盘,命名为closeType,依然标著IBAction用来声明这是一个响应操作。看代码:

viewController.h:

 

[plain] view plaincopyprint?
  1. #import <UIKit/UIKit.h> 
  2.  
  3. @interface ViewController : UIViewController 
  4. @property (retain, nonatomic) IBOutlet UILabel *myLabel; 
  5.  
  6. @property (retain, nonatomic) IBOutlet UISlider *mySlider; 
  7.  
  8. @property (retain, nonatomic) IBOutlet UITextField *myTextField; 
  9. @property (retain, nonatomic) IBOutlet UIButton *myButton; 
  10. -(IBAction)closeType:(id)sender; 
  11. -(IBAction)sliderChanged:(id)sender; 
  12.  
  13.  
  14. @end 
#import <UIKit/UIKit.h>

@interface ViewController : UIViewController
@property (retain, nonatomic) IBOutlet UILabel *myLabel;

@property (retain, nonatomic) IBOutlet UISlider *mySlider;

@property (retain, nonatomic) IBOutlet UITextField *myTextField;
@property (retain, nonatomic) IBOutlet UIButton *myButton;
-(IBAction)closeType:(id)sender;
-(IBAction)sliderChanged:(id)sender;


@end

viewController.m:

 

 

[plain] view plaincopyprint?
  1. #import "ViewController.h" 
  2.  
  3. @interface ViewController () 
  4.  
  5. @end 
  6.  
  7. @implementation ViewController 
  8. @synthesize myLabel; 
  9. @synthesize mySlider; 
  10. @synthesize myTextField; 
  11. @synthesize myButton; 
  12. -(IBAction)closeType:(id)sender//该方法与UIControl的touch down行为联系。 
  13.     [myTextField resignFirstResponder]; 
  14.     //这个方法由UIControl的touch down行为触发 
  15.     //取消myTextField的第一响应者身份用来关闭键盘 
  16. -(IBAction)sliderChanged:(id)sender//将该方法与slider的value changed行为联系。 
  17.     UISlider *slider = (UISlider *)sender;//转型 
  18.      
  19.     //将当前的slider的值取出转成字符串并改变label的标题 
  20.     NSString *str = [[NSString alloc] initWithFormat:@"%f",slider.value]; 
  21.     myLabel.text=str; 
  22.      
  23.     //改变各个控件的透明度为当前的slide的值。 
  24.     myLabel.alpha=slider.value; 
  25.     myTextField.alpha=slider.value; 
  26.     myButton.alpha=slider.value; 
  27.      
  28.     //释放使用过的str 
  29.     [str release]; 
  30.      
  31.      
  32.  
  33. - (void)viewDidLoad 
  34.     [super viewDidLoad]; 
  35.     // Do any additional setup after loading the view, typically from a nib. 
  36.  
  37. - (void)viewDidUnload 
  38.      
  39.     [self setMyLabel:nil]; 
  40.     [self setMySlider:nil]; 
  41.     [self setMyTextField:nil]; 
  42.     [self setMyButton:nil]; 
  43.     [super viewDidUnload]; 
  44.     // Release any retained subviews of the main view. 
  45.  
  46. - (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation 
  47.     return (interfaceOrientation != UIInterfaceOrientationPortraitUpsideDown); 
  48.  
  49. - (void)dealloc { 
  50.     
  51.     [myLabel release]; 
  52.     [mySlider release]; 
  53.     [myTextField release]; 
  54.     [myButton release]; 
  55.     [super dealloc]; 
  56. @end 
#import "ViewController.h"

@interface ViewController ()

@end

@implementation ViewController
@synthesize myLabel;
@synthesize mySlider;
@synthesize myTextField;
@synthesize myButton;
-(IBAction)closeType:(id)sender//该方法与UIControl的touch down行为联系。
{
    [myTextField resignFirstResponder];
    //这个方法由UIControl的touch down行为触发
    //取消myTextField的第一响应者身份用来关闭键盘
}
-(IBAction)sliderChanged:(id)sender//将该方法与slider的value changed行为联系。
{
    UISlider *slider = (UISlider *)sender;//转型
    
    //将当前的slider的值取出转成字符串并改变label的标题
    NSString *str = [[NSString alloc] initWithFormat:@"%f",slider.value];
    myLabel.text=str;
    
    //改变各个控件的透明度为当前的slide的值。
    myLabel.alpha=slider.value;
    myTextField.alpha=slider.value;
    myButton.alpha=slider.value;
    
    //释放使用过的str
    [str release];
    
    
}

- (void)viewDidLoad
{
    [super viewDidLoad];
	// Do any additional setup after loading the view, typically from a nib.
}

- (void)viewDidUnload
{
    
    [self setMyLabel:nil];
    [self setMySlider:nil];
    [self setMyTextField:nil];
    [self setMyButton:nil];
    [super viewDidUnload];
    // Release any retained subviews of the main view.
}

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
    return (interfaceOrientation != UIInterfaceOrientationPortraitUpsideDown);
}

- (void)dealloc {
   
    [myLabel release];
    [mySlider release];
    [myTextField release];
    [myButton release];
    [super dealloc];
}
@end

以上控件与IBAction的联系操作我就不画图了,与上次内容一样,这时我们就可以查看效果了:

 

 

好了,slider改变透明度完成了,这时我们来解释一下在设置图片背景时,为什么要取消用户响应,也就是如下这个选项是不勾选的:

 

因为我们在点击textField时会自动弹出软键盘进行编辑,我们需要触摸touch down空闲部分来关闭软键盘,我们的做法是将xib文件的view identity从UIView 改为它的子类UIControl,这样就能响应空闲地方的touch down行为,触动操作方法来关闭键盘,如果我们勾选上图片背景的交互选项,这个view就会被当作是UIControl上的一个控件,但是这个控件是没有touch down行为的,所以这时不会触发,如果取消交互选项,那么在touch图片时,该图片会捕捉到touch down,没有该行为就将其传给下面的UIControl来让其解决,所谓隔山打牛,触碰了该图片,其实就是触碰了UIControl,产生了touch down,所以就能关闭键盘了。写得有点儿啰嗦,多试试就知道是怎么回事了。

 

posted on 2012-11-08 18:08  水至清则无鱼  阅读(233)  评论(0编辑  收藏  举报

导航