// MARK: 提示框

func _initAlertView() {

let btn = UIButton(type: UIButtonType.ContactAdd)

btn.frame = CGRect(x: 100, y: 150, width: 50, height: 50)

btn.addTarget(self, action: "showAlert", forControlEvents: UIControlEvents.TouchUpInside)

self.view.addSubview(btn)

}

func showAlert() {

//        let alertView = UIAlertView(title: "警告", message: "密码错误", delegate: self, cancelButtonTitle: "取消", otherButtonTitles: "确定")

////        let alertView = UIAlertView(title: "警告", message: "密码错误", delegate: self, cancelButtonTitle: "取消")

//

//        //设置alertView的样式

//        alertView.alertViewStyle = UIAlertViewStyle.LoginAndPasswordInput

//        alertView.show()

let alertCtrl = UIAlertController(title: "温馨提示", message: "输入账号和密码", preferredStyle: UIAlertControllerStyle.Alert)

alertCtrl.addTextFieldWithConfigurationHandler { (textField) -> Void in

textField.placeholder = "输入账号"

}

alertCtrl.addTextFieldWithConfigurationHandler { (textField) -> Void in

textField.placeholder = "输入密码"

textField.secureTextEntry = true

}

let sureAction = UIAlertAction(title: "确定", style: UIAlertActionStyle.Destructive) { (alertAction) -> Void in

let tfs: [UITextField] = alertCtrl.textFields!

let tf1: UITextField = tfs[0]

let tf2: UITextField = tfs[1]

print("确定:\(alertAction.title)")

print(tf1.text)

print(tf2.text)

}

let cancelAction = UIAlertAction(title: "取消", style: UIAlertActionStyle.Destructive) { (alertAction) -> Void in

print("取消:\(alertAction.title)")

}

alertCtrl.addAction(sureAction)

alertCtrl.addAction(cancelAction)

self.presentViewController(alertCtrl, animated: true, completion: nil)

}

// MARK: 提示界面

func _initActionSheet() {

let btn = UIButton(type: UIButtonType.InfoDark)

btn.frame = CGRect(x: 200, y: 150, width: 50, height: 50)

btn.addTarget(self, action: "showActionSheet", forControlEvents: UIControlEvents.TouchUpInside)

self.view.addSubview(btn)

}

func showActionSheet() {

//        let actionSheet = UIActionSheet(title: "提示", delegate: self, cancelButtonTitle: "取消", destructiveButtonTitle: "确定", otherButtonTitles: "按钮1", "按钮2")

//        actionSheet.showInView(self.view)

let alertCtrl = UIAlertController(title: "提示", message: "重点提示Message", preferredStyle: UIAlertControllerStyle.ActionSheet)

let sureAction = UIAlertAction(title: "确定", style: UIAlertActionStyle.Default) { (alertAction) -> Void in

print("确定:\(alertAction.title)")

}

let cancelAction = UIAlertAction(title: "取消", style: UIAlertActionStyle.Cancel) { (alertAction) -> Void in

print("取消:\(alertAction.title)")

}

alertCtrl.addAction(sureAction)

alertCtrl.addAction(cancelAction)

self.presentViewController(alertCtrl, animated: true, completion: nil)

}

// MARK: UISegmentedControl 两种创建方式都实用

func _initsegmentControl() {

// 1.0 设置按钮的标题数组

let array: [String] = ["选择","搜索","工具"]

// 1.1 创建分段控件

let segmentCtrl = UISegmentedControl(items: array)

segmentCtrl.frame = CGRect(x: 100, y: 100, width: 150, height: 25)

// 1.2 设置默认选中按钮

segmentCtrl.selectedSegmentIndex = 0

segmentCtrl.addTarget(self, action: "segmentAction:", forControlEvents: UIControlEvents.ValueChanged)

self.view.addSubview(segmentCtrl)

// 2.0 设置按钮的标题数组

let arrayString:[String] = ["11","22","33"];

// 2.1 创建分段控件

let segmentContrl = UISegmentedControl(items: arrayString)

segmentContrl.frame = CGRectMake(100, 200, 200, 50)

// 2.2 设置默认选中按钮

segmentContrl.selectedSegmentIndex = 2

segmentContrl.addTarget(self, action: "segmentAction:", forControlEvents: UIControlEvents.ValueChanged)

self.view.addSubview(segmentContrl)

}

func segmentAction(segment: UISegmentedControl) {

print(segment.selectedSegmentIndex)

switch segment.selectedSegmentIndex{

case 0:

print("选择")

case 1:

print("搜索")

case 2:

print("工具")

default: break

}

}

Swift UIAlertController、UISegmentedControl的更多相关文章

  1. UISwitch(开关控件)、UISegmentedControl(分段控件)

    一.UISwitch 1.初始化 UISwitch *s1 = [[UISwitch alloc]initWithFrame:CGRectMake(50, 170, 100, 200)];   2.设 ...

  2. iOS开发之七:常用控件--UISlider、UISegmentedControl、UIPageControl的使用

    一.UISlider的使用 其实UISlider在iOS开发中用的似乎不是很多,我们看到的用到的地方多是音乐播放器的音量控制,以及视频播放器中的音量控制. 还是记录一下吧! 1.常用属性 // 设置获 ...

  3. UI中一些不常用的控件UIActivityIndicatorView、UIProgressView、UISegmentedControl、UIStepper、UISwitch、UITextView、UIAlertController

    //UIActivityIndicatorView //小菊花,加载 #import "ActivityIndicatorVC.h" @interface ActivityIndi ...

  4. UI-不常用控件 UIActivityIndicatorView、UIProgressView、UISegmentedControl、UIStepper、UISwitch、UITextView、UIAlertController

    1 //UIActivityIndicatorView //小菊花,加载================================================================ ...

  5. [Swift]UIAlertController 以及 Swift 中的闭包和枚举

    原文地址:http://blog.callmewhy.com/2014/10/08/uialertcontroller-swift-closures-enum/ 在 iOS8 的 SDK 中, UIK ...

  6. 友盟(Swift)-集成、统计用户数量、具体页面访问数量、具体按钮点击数量

    什么是友盟.有什么用? 这些傻瓜问题这里就不解释了,可以自己百度去. 友盟提供的文档和demo都是oc的,这里用swift写了一个小demo,在此分享一下. 步骤1:友盟后台注册应用(iOS),拿到a ...

  7. [转载] 对象存储(2):OpenStack Swift——概念、架构与规模部署

    原文: http://www.testlab.com.cn/Index/article/id/1085.html#rd?sukey=fc78a68049a14bb228cb2742bdec2b9498 ...

  8. Openstack Swift 原理、架构与 API 介绍

    OpenStack Swift 开源项目提供了弹性可伸缩.高可用的分布式对象存储服务,适合存储大规模非结构化数据.本文将深入介绍 Swift 的基本设计原理.对称式的系统架构和 RESTful API ...

  9. swift 实践- 08 -- UISegmentedControl

    import UIKit class ViewController: UIViewController { override func viewDidLoad() { super.viewDidLoa ...

随机推荐

  1. VirtualBox安装RedHat7

    软件准备 VirtualBox-5.2.8-121009-Win.exe rhel-server-7.4-x86_64-dvd.iso 安装环境 win10 安装步骤: 1.先在win10系统中安装V ...

  2. 第五篇:Spark SQL Catalyst源码分析之Optimizer

    /** Spark SQL源码分析系列文章*/ 前几篇文章介绍了Spark SQL的Catalyst的核心运行流程.SqlParser,和Analyzer 以及核心类库TreeNode,本文将详细讲解 ...

  3. Docker 坑点记录

    1 关于 Docker Windows 文件夹问题 C:\Users Docker Machine tries to auto-share your /Users (OS X) or C:\Users ...

  4. 经典C#面试题

    1.在下面的代码中,如何引用命名空间fabulous中的great? namespace fabulous{// code in fabulous namespace}namespace super{ ...

  5. JavaScript高级程序设计-读书笔记(1)

    第1章 JavaScript简介 JavaScript是一种专为与网页交互而设计的脚本语言,由下列三个不同的部分组成: l        ECMAScript:提供核心语言功能: l        文 ...

  6. C3 文件IO:APUE 笔记

    C3:文件IO 1 引言 本章描述的函数被成为不带缓冲的IO,涉及5个函数:open.read.write.lseek.close. 文件控制:dup.sync.fsync.fdatasync.fcn ...

  7. HTML5如何做横屏适配

    在移动端中我们经常碰到横屏竖屏的问题,那么我们应该如何去判断或者针对横屏.竖屏来写不同的代码呢. 首先在head中加入如下代码: 1 <meta name="viewport" ...

  8. phalcon: dispatcher->forward地址转发/重定向

    比如,我indexController里面的indexAction,因为用户没有穿参数,我要重定向到 errorAction里面 $this->dispatcher->forward(ar ...

  9. 场景设计以及Manual Scenario和Goal-OrientedScenario的区别

    Manual Scenario 手工场景 主要是设计用户变化,通过手工场景可以帮助我们分析系统的性能瓶颈.手动方案:如果要生成手动方案,请选择此方法.通过创建组并指定脚本.负载生成器和每组中包括的 V ...

  10. C#/JAVA 程序员转GO/GOLANG程序员笔记大全(DAY 00)

    一.安装说明 https://studygolang.com/dl 二.环境变量 // 下载 *.msi 安装文件,部分环境变量默认配置好了. 其他配置如下描述 三.目录及项目层级关系 在系统环境变量 ...