iOS开发中UISwitch按钮的使用方法简介

一、第一种创建UISwitch控件的方法,在代码中动态创建。
1、打开Xcode  4.3.2, 新建项目Switch,选择Single View Application。
2、打开ViewController.m文件在viewDidLoad方法里添加代码:

代码如下:

- (void)viewDidLoad
{
    [super viewDidLoad];
    UISwitch *switchButton = [[UISwitch alloc] initWithFrame:CGRectMake(50, 100, 20, 10)];
    [switchButton setOn:YES];
    [switchButton addTarget:self action:@selector(switchAction:) forControlEvents:UIControlEventValueChanged];
    [self.view addSubview:switchButton];
   
 // Do any additional setup after loading the view, typically from a nib.
}

代码中selector中的switchAction:需要我们自己实现,就是按下时接收到的事件。
记得把switchButton加到当前view,调用[self.viewaddSubview:switchButton];
3、监听UISwitch按下事件
实现代码如下:

代码如下:

-(void)switchAction:(id)sender
{
    UISwitch *switchButton = (UISwitch*)sender;
    BOOL isButtonOn = [switchButton isOn];
    if (isButtonOn) {
        showSwitchValue.text = @"是";
    }else {
        showSwitchValue.text = @"否";
    }
}

showSwitchValue是我通过拖拽控件方法放到界面上的Label,方便显示效果
运行,效果:

二、通过拖拽方法使用UISwitch
1、往xib文件上拖拽一个UISwitch控件。

2、按alt+command + return键开启Assistant Editor模式,选中UISwitch控件,按住Control键,往ViewController.h拖拽

3、选Action方式

4、.m文件中实现switchAction 。刚才动态创建的时候也用到这个方法名称,可以先注释掉刚才的。

代码如下:

- (IBAction)switchAction:(id)sender {
    UISwitch *switchButton = (UISwitch*)sender;
    BOOL isButtonOn = [switchButton isOn];
    if (isButtonOn) {
        showSwitchValue.text = @"是";
    }else {
        showSwitchValue.text = @"否";
    }
}

这里我们来看一下.m文件的源码:

代码如下:

#import "HMCustomSwitch.h"

@implementation HMCustomSwitch

@synthesize on;
@synthesize tintColor, clippingView, leftLabel, rightLabel;

+(HMCustomSwitch *)switchWithLeftText:(NSString *)leftText andRight:(NSString *)rightText
{
 HMCustomSwitch *switchView = [[HMCustomSwitch alloc] initWithFrame:CGRectZero];
 
 switchView.leftLabel.text = leftText;
 switchView.rightLabel.text = rightText;
 
 return [switchView autorelease];
}

-(id)initWithFrame:(CGRect)rect
{
 if ((self=[super initWithFrame:CGRectMake(rect.origin.x,rect.origin.y,95,27)]))
 {
  //  self.clipsToBounds = YES;
  
  [self awakeFromNib];  // do all setup in awakeFromNib so that control can be created manually or in a nib file
 }
 return self;
}

-(void)awakeFromNib
{
 [super awakeFromNib];
 
 self.backgroundColor = [UIColor clearColor];

[self setThumbImage:[UIImage imageNamed:@"switchThumb.png"] forState:UIControlStateNormal];
 [self setMinimumTrackImage:[UIImage imageNamed:@"switchBlueBg.png"] forState:UIControlStateNormal];
 [self setMaximumTrackImage:[UIImage imageNamed:@"switchOffPlain.png"] forState:UIControlStateNormal];
 
 self.minimumValue = 0;
 self.maximumValue = 1;
 self.continuous = NO;
 
 self.on = NO;
 self.value = 0.0;
 
 self.clippingView = [[UIView alloc] initWithFrame:CGRectMake(4,2,87,23)];
 self.clippingView.clipsToBounds = YES;
 self.clippingView.userInteractionEnabled = NO;
 self.clippingView.backgroundColor = [UIColor clearColor];
 [self addSubview:self.clippingView];
 [self.clippingView release];
 
 NSString *leftLabelText = NSLocalizedString(@"ON","Custom UISwitch ON label. If localized to empty string then I/O will be used");
 if ([leftLabelText length] == 0) 
 {
  leftLabelText = @"l";  // use helvetica lowercase L to be a 1.
 }
 
 self.leftLabel = [[UILabel alloc] init];
 self.leftLabel.frame = CGRectMake(0, 0, 48, 23);
 self.leftLabel.text = leftLabelText;
 self.leftLabel.textAlignment = NSTextAlignmentCenter;
 self.leftLabel.font = [UIFont boldSystemFontOfSize:17];
 self.leftLabel.textColor = [UIColor whiteColor];
 self.leftLabel.backgroundColor = [UIColor clearColor];
 //  self.leftLabel.shadowColor = [UIColor redColor];
 //  self.leftLabel.shadowOffset = CGSizeMake(0,0);
 [self.clippingView addSubview:self.leftLabel];
 [self.leftLabel release];
 
 
 NSString *rightLabelText = NSLocalizedString(@"OFF","Custom UISwitch OFF label. If localized to empty string then I/O will be used");
 if ([rightLabelText length] == 0) 
 {
  rightLabelText = @"O"; // use helvetica uppercase o to be a 0.
 }
 
 self.rightLabel = [[UILabel alloc] init];
 self.rightLabel.frame = CGRectMake(95, 0, 48, 23);
 self.rightLabel.text = rightLabelText;
 self.rightLabel.textAlignment = NSTextAlignmentCenter;
 self.rightLabel.font = [UIFont boldSystemFontOfSize:17];
 self.rightLabel.textColor = [UIColor grayColor];
 self.rightLabel.backgroundColor = [UIColor clearColor];
 //  self.rightLabel.shadowColor = [UIColor redColor];
 //  self.rightLabel.shadowOffset = CGSizeMake(0,0);
 [self.clippingView addSubview:self.rightLabel];
 [self.rightLabel release];
 
 
}

-(void)layoutSubviews
{
 [super layoutSubviews];
 
 // NSLog(@"leftLabel=%@",NSStringFromCGRect(self.leftLabel.frame));
 
 // move the labels to the front
 [self.clippingView removeFromSuperview];
 [self addSubview:self.clippingView];
 
 CGFloat thumbWidth = self.currentThumbImage.size.width;
 CGFloat switchWidth = self.bounds.size.width;
 CGFloat labelWidth = switchWidth - thumbWidth;
 CGFloat inset = self.clippingView.frame.origin.x;
 
 // NSInteger xPos = self.value * (self.bounds.size.width - thumbWidth) - (self.leftLabel.frame.size.width - thumbWidth/2);
 NSInteger xPos = self.value * labelWidth - labelWidth - inset;
 self.leftLabel.frame = CGRectMake(xPos, 0, labelWidth, 23);
 
 // xPos = self.value * (self.bounds.size.width - thumbWidth) + (self.rightLabel.frame.size.width - thumbWidth/2);
 xPos = switchWidth + (self.value * labelWidth - labelWidth) - inset;
 self.rightLabel.frame = CGRectMake(xPos, 0, labelWidth, 23);
 
 // NSLog(@"value=%f    xPos=%i",self.value,xPos);
 // NSLog(@"thumbWidth=%f    self.bounds.size.width=%f",thumbWidth,self.bounds.size.width);
}

- (UIImage *)image:(UIImage*)image tintedWithColor:(UIColor *)tint

 
    if (tint != nil)
 {
  UIGraphicsBeginImageContext(image.size);
  
  //draw mask so the alpha is respected
  CGContextRef currentContext = UIGraphicsGetCurrentContext();
  CGImageRef maskImage = [image CGImage];
  CGContextClipToMask(currentContext, CGRectMake(0, 0, image.size.width, image.size.height), maskImage);
  CGContextDrawImage(currentContext, CGRectMake(0,0, image.size.width, image.size.height), image.CGImage);
  
  [image drawAtPoint:CGPointMake(0,0)];
  [tint setFill];
  UIRectFillUsingBlendMode(CGRectMake(0,0,image.size.width,image.size.height),kCGBlendModeColor);
  UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();
  UIGraphicsEndImageContext();
  
        return newImage;
    }
    else
 {
        return image;
    }
}

-(void)setTintColor:(UIColor*)color
{
 if (color != tintColor)
 {
  [tintColor release];
  tintColor = [color retain];
  
  [self setMinimumTrackImage:[self image:[UIImage imageNamed:@"switchBlueBg.png"] tintedWithColor:tintColor] forState:UIControlStateNormal];
 }
 
}

- (void)setOn:(BOOL)turnOn animated:(BOOL)animated;
{
 on = turnOn;
 
 if (animated)
 {
  [UIView  beginAnimations:nil context:nil];
  [UIView setAnimationDuration:0.2];
 }
 
 if (on)
 {
  self.value = 1.0;
 }
 else
 {
  self.value = 0.0;
 }
 
 if (animated)
 {
  [UIView commitAnimations]; 
 }
}

- (void)setOn:(BOOL)turnOn
{
 [self setOn:turnOn animated:NO];
}

- (void)endTrackingWithTouch:(UITouch *)touch withEvent:(UIEvent *)event
{
 NSLog(@"preendTrackingWithtouch");
 [super endTrackingWithTouch:touch withEvent:event];
 NSLog(@"postendTrackingWithtouch");
 m_touchedSelf = YES;
 
 [self setOn:on animated:YES];
}

- (void)touchesBegan:(NSSet*)touches withEvent:(UIEvent*)event
{
 [super touchesBegan:touches withEvent:event];
  NSLog(@"touchesBegan");
 m_touchedSelf = NO;
 on = !on;
}

- (void)touchesEnded:(NSSet*)touches withEvent:(UIEvent*)event
{
 [super touchesEnded:touches withEvent:event];
 NSLog(@"touchesEnded");
 
 if (!m_touchedSelf)
 {
  [self setOn:on animated:YES];
  [self sendActionsForControlEvents:UIControlEventValueChanged];
 }
}

-(void)dealloc
{
 [tintColor release];
 [clippingView release];
 [rightLabel release];
 [leftLabel release];
 
 [super dealloc];
}

@end

看代码可以知道,其实它是通过继承UISlider控件实现的,UISlider的左右分别是个UILabel,当YES的时候,滑块滑到了最右边,NO的时候滑到了最左边。
所以在代码中使用它呢?这里再举一个例子:

代码如下:

- (void)loadView
{
 UIView *contentView = [[UIView alloc] initWithFrame:[[UIScreen mainScreen] applicationFrame]];
 self.view = contentView;
 contentView.backgroundColor = [UIColor whiteColor];
 
 // Standard ON/OFF
 HMCustomSwitch *switchView = [[HMCustomSwitch alloc] initWithFrame:CGRectZero];
 switchView.center = CGPointMake(160.0f, 20.0f);
 switchView.on = YES;
 [contentView addSubview:switchView];
 [switchView release];
 
 // Custom YES/NO
 switchView = [HMCustomSwitch switchWithLeftText:@"YES" andRight:@"NO"];
 switchView.center = CGPointMake(160.0f, 60.0f);
 switchView.on = YES;
 [contentView addSubview:switchView];
 
 // Custom font and color
 switchView = [HMCustomSwitch switchWithLeftText:@"Hello " andRight:@"ABC "];
 switchView.center = CGPointMake(160.0f, 100.0f);
 switchView.on = YES;
 [switchView.leftLabel setFont:[UIFont boldSystemFontOfSize:13.0f]];
 [switchView.rightLabel setFont:[UIFont italicSystemFontOfSize:15.0f]];
 [switchView.rightLabel setTextColor:[UIColor blueColor]];
 [contentView addSubview:switchView];
 
 // Multiple lines
 switchView = [HMCustomSwitch switchWithLeftText:@"Hello\nWorld" andRight:@"Bye\nWorld"];
 switchView.center = CGPointMake(160.0f, 140.0f);
 switchView.on = YES;
 switchView.tintColor = [UIColor orangeColor];
 switchView.leftLabel.font = [UIFont boldSystemFontOfSize:9.0f];
 switchView.rightLabel.font = [UIFont boldSystemFontOfSize:9.0f];
 switchView.leftLabel.numberOfLines = 2;
 switchView.rightLabel.numberOfLines = 2;
 switchView.leftLabel.lineBreakMode = NSLineBreakByWordWrapping;
 switchView.rightLabel.lineBreakMode = NSLineBreakByWordWrapping;
 [contentView addSubview:switchView];
 
 switchView = [[HMCustomSwitch alloc] init];
 switchView.center = CGPointMake(160.0f, 180.0f);
 switchView.on = YES;
 switchView.tintColor = [UIColor purpleColor];
 [contentView addSubview:switchView];
 [switchView release];
 
 switchView = [HMCustomSwitch switchWithLeftText:@"l" andRight:@"O"];
 switchView.center = CGPointMake(160.0f, 220.0f);
// customSwitch.tintColor = [UIColor colorWithRed:125.f/255.f green:157.f/255.f blue:93.f/255.f alpha:1.0];
// customSwitch.tintColor = [UIColor colorWithRed:125.f/255.f green:157.f/255.f blue:93.f/255.f alpha:1.0];
 [contentView addSubview:switchView];

// Standard ON/OFF
 switchView = [[HMCustomSwitch alloc] init];
 switchView.center = CGPointMake(160.0f, 260.0f);
 switchView.tintColor = [UIColor colorWithRed:125.f/255.f green:157.f/255.f blue:93.f/255.f alpha:1.0];
 [switchView addTarget:self action:@selector(switchFlipped:) forControlEvents:UIControlEventValueChanged];
 [contentView addSubview:switchView];
 [switchView release];
 
 
 
 UIToolbar *toolbar = [[UIToolbar alloc] initWithFrame:CGRectMake(0, 420, 320, 40)];
 toolbar.tintColor = [UIColor colorWithRed:125.f/255.f green:157.f/255.f blue:93.f/255.f alpha:1.0];
 [contentView addSubview:toolbar];
 
 [contentView release];
}

-(void)switchFlipped:(HMCustomSwitch*)switchView
{
 NSLog(@"switchFlipped=%f  on:%@",switchView.value, (switchView.on?@"Y":@"N"));
 
}

(0)

相关推荐

  • iOS 增加右侧按钮功能实例代码

    一,工程图. 二,代码. ViewController.m - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typically from a nib. //增加右侧按钮 [self addRightButton]; } #pragma -mark -functions //增加右侧按钮 -(void)addRightButton { UIBarButtonI

  • 详解iOS应用中自定义UIBarButtonItem导航按钮的创建方法

    iOS系统导航栏中有leftBarButtonItem和rightBarButtonItem,我们可以根据自己的需求来自定义这两个UIBarButtonItem. 四种创建方法 系统提供了四种创建的方法: 复制代码 代码如下: - (instancetype)initWithBarButtonSystemItem:(UIBarButtonSystemItem)systemItem target:(id)target action:(SEL)action; - (instancetype)init

  • iOS App中UITableView左滑出现删除按钮及其cell的重用

    UITableView的编辑模式 实现UITableView简单的删除功能(左滑出现删除按钮) 首先UITableView需要进入编辑模式.实现下面的方法,即使什么代码也不写也会进入编辑模式: 复制代码 代码如下: - (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)index

  • IOS UITableViewCell详解及按钮点击事件处理实例

    IOS UITableViewCell详解及按钮点击事件处理 今天突然做项目的时候,又遇到处理自定义的UITableViewCell上按钮的点击事件问题.我知道有两种方式,可是突然想不起来之前是怎么做的了,好记性不如烂笔头,还是记录一下吧. 1.第一种方式给Button加上tag值 这里分为两种:一种是直接在原生的UITableViewCell上添加UIButton按钮,然后给UIButton设置tag值,然后在控制器里的方法里通过取数据,做界面跳转等.还是举个例子吧,省的回忆半天. - (UI

  • IOS 开发之自定义按钮实现文字图片位置随意定制

    IOS 开发之自定义按钮实现文字图片位置随意定制 可能有些看到这篇文章的朋友会觉得很不屑:"按钮谁不会自定义?还需要看你的?" 也确实,按钮是我们项目中最常见的控件之一,天天在使用.对于不同类型的按钮,我们是否有更加简便的方法来实现需求是我们需要做的.这里我提出自己的两种方法,您可以对你自己平时自定义按钮的方法做一下对比,看看哪种方法更加简单. 多说一句,千万不要觉得知识简单,觉得自己会了,没必要学习.'往往简单的东西存在大智慧'(这个比给满分),知识都是慢慢积累出来的. 按钮是应用中

  • iOS应用开发中导航栏按钮UIBarButtonItem的添加教程

    1.UINavigationController导航控制器如何使用 UINavigationController可以翻译为导航控制器,在iOS里经常用到. 我们看看它的如何使用: 下面的图显示了导航控制器的流程.最左侧是根视图,当用户点击其中的General项时 ,General视图会滑入屏幕:当用户继续点击Auto-Lock项时,Auto-Lock视图将滑入屏幕.相应地,在对象管理上,导航控制器使用了导航堆栈.根视图控制器在堆栈最底层,接下来入栈的是General视图控制器和Auto-Lock

  • 关于iOS导航栏返回按钮问题的解决方法

    最近遇到一个关于导航栏返回按钮的问题,因为之前项目里面都是用的系统默认的返回按钮样式所以没有想过要去更改,后来有需要将返回按钮箭头旁边的文字去掉,同时将该返回按钮的点击事件重新定义.一开始尝试自定义按钮然后设置为leftBarButtonItem,但是这样图片可能跟系统自带的不一样,还有就是返回按钮的位置跟系统自带的不一样.后来找了一些资料,发现将文字去掉比较简单,一般做法是控制器中添加如下代码,然后他的下一级控制就有一个只有箭头没有文字返回按钮: 复制代码 代码如下: UIBarButtonI

  • iOS开发中UISwitch按钮的使用方法简介

    一.第一种创建UISwitch控件的方法,在代码中动态创建. 1.打开Xcode  4.3.2, 新建项目Switch,选择Single View Application. 2.打开ViewController.m文件在viewDidLoad方法里添加代码: 复制代码 代码如下: - (void)viewDidLoad {     [super viewDidLoad];     UISwitch *switchButton = [[UISwitch alloc] initWithFrame:C

  • iOS开发中WebView的基本使用方法简介

    1.使用UIWebView加载网页 运行XCode 4.3,新建一个Single View Application,命名为WebViewDemo. 2.加载WebView 在ViewController.h添加WebView成员变量和在ViewController.m添加实现 复制代码 代码如下: #import <UIKit/UIKit.h> @interface ViewController : UIViewController {     UIWebView *webView; } @e

  • IOS开发中键盘输入屏幕上移的解决方法

    在IOS开法中经常会遇到键盘遮挡屏幕的事情(比如输入账号密码验证码等等),就使得原本都不大的屏幕直接占了一半甚至更多的位置,这倒无所谓,关键是挡住了下面的按钮.这样的话按钮的事件也就触发不了,最好的解决办法就是当输入这些信息的时候让整个屏幕上移一个键盘的位置,或者上移到指定的位置. 首先一般输入的话都用的是UITextField,所以要监听用户什么时候开始输入和什么时候结束输入,直接设置代理代理就行了,要遵受 UITextFieldDelegate协议. //遵循协议 @interface Vi

  • iOS开发中runtime常用的几种方法示例总结

    前言 Objective-C runtime是一个实现Objective-C语言的C库.它是一门编译型语言.也是一门动态型的语言(这里强调下OC是静态类型语言),之前没接触runtime的时候也不觉着它有多重要,接触之后才发现其实runtime挺强大的.就拿我们在iOS开发中所使用的OC编程语言来讲,OC之所以能够做到即是编译型语言,又能做到动态语言,就是得益于runtime的机制. 最近公司项目中用了一些 runtime 相关的知识, 初看时有些蒙, 虽然用的并不多, 但还是想着系统的把 ru

  • IOS开发中加载大量网络图片优化方法

    IOS开发中加载大量网络图片如何优化 1.概述 在IOS下通过URL读一张网络图片并不像其他编程语言那样可以直接把图片路径放到图片路径的位置就ok,而是需要我们通过一段类似流的方式去加载网络图片,接着才能把图片放入图片路径显示.比如: -(UIImage *) getImageFromURL:(NSString *)fileURL { //NSLog(@"执行图片下载函数"); UIImage * result; NSData * data = [NSData dataWithCont

  • iOS开发中Swift3 监听UITextView文字改变的方法(三种方法)

    在项目中使用文本输入框出UITextField之外还会经常使用 UITextView ,难免会有需求监听UITextView文本框内文本数量.下面介绍在swift3中两种常用方式 方式一: 全局通知 1.注册通知 在合适位置注册监听UITextView文本变化的全局通知 //UITextView 监听开始输入的两种方法 //方法一:通知 NotificationCenter.default.addObserver(self, selector: #selector(ComposeVC.textV

  • iOS开发中使用CoreLocation框架处理地理编码的方法

    一.简介 1.在移动互联网时代,移动app能解决用户的很多生活琐事,比如 (1)导航:去任意陌生的地方 (2)周边:找餐馆.找酒店.找银行.找电影院 2.在上述应用中,都用到了地图和定位功能,在iOS开发中,要想加入这2大功能,必须基于2个框架进行开发 (1)Map Kit :用于地图展示 (2)Core Location :用于地理定位 3.两个热门专业术语 (1)LBS :Location Based Service(基于定位的服务) (2)SoLoMo :Social Local Mobi

  • Android开发中button按钮的使用及动态添加组件方法示例

    本文实例讲述了Android开发中button按钮的使用及动态添加组件方法.分享给大家供大家参考,具体如下: MainActivity.java package com.example.lab2; import android.os.Bundle; import android.app.Activity; import android.content.Context; import android.view.Menu; import android.view.View; import andro

  • iOS开发中判断字符串为空的方法

    前言: 判断字符串为空:看似简单的问题,有人会说不就使用[string isEqualToString:@""]或者更简单的string.text == nil就行了嘛.但是并没有考虑到其中存在的一些问题,例如当字符串中存在空格或者换行时或者当请求后台数据时得到的是进行JSON解析的时候, 如果解析出的NSDictionary中某个key对应的value为空, 则系统会把它处理为NSNull类的单例对象.这些情况下,上面的判断方法就不会起到作用. 具体实现: + (BOOL)isBla

  • 详解IOS开发中生成推送的pem文件

    详解IOS开发中生成推送的pem文件 具体步骤如下: 首先,需要一个pem的证书,该证书需要与开发时签名用的一致. 具体生成pem证书方法如下: 1. 登录到 iPhone Developer Connection Portal(http://developer.apple.com/iphone/manage/overview/index.action )并点击 App IDs 2. 创建一个不使用通配符的 App ID .通配符 ID 不能用于推送通知服务.例如,  com.itotem.ip

随机推荐