iOS开发——UI篇Swift篇&UITextView
UITextView
一:UITextView使用及其属性的设置
titleLabel.text = titleString
//创建UITextView对象
textView = UITextView(frame:CGRectMake(10.0, 120.0, 300.0, 200.0))
//为方便看到效果,设置背景颜色
textView.backgroundColor = UIColor.grayColor()
//添加到视图上
self.view.addSubview(textView)
//------------------ 常用属性
//设置textview里面的字体颜色
textView.textColor = UIColor.greenColor()
//设置文本字体
textView.font = UIFont.systemFontOfSize();//使用系统默认字体,指定14号字号
textView.font = UIFont(name: )//指定字体,指定字号
//设置它的背景颜色
textView.backgroundColor = UIColor.grayColor()
//设置显示内容
textView.text = "经常听到:\n 被中介骗了,押金不退,晚一天交房租,被讹了。\n\n租房普遍现象:\n网上报价不真实?经常被忽悠!(看房时报价都比网上高!)\n证件不齐全,被骗过!(其实根本不是房东啦!)\n看房前态度都很热情!\n签约之后态度骤变!\n入住后家电维修只能靠自己!\n房屋到期,押金各种被勒索!\n\n现在开始,你来改变这一切!\n《租房点评》为你而备,租房无忧!\n\n再也不用担心被欺骗,想要知道给你介绍房子的人好不好,《租房点评》告诉你!"
//文本对齐方式
textView.textAlignment = NSTextAlignment.Right
//文本视图设置圆角
textView.layer.cornerRadius =
//是否允许点击链接和附件
textView.selectable = true
//返回键的类型
textView.returnKeyType = UIReturnKeyType.Done
//键盘类型
textView.keyboardType = UIKeyboardType.Default
//是否可以滚动
textView.scrollEnabled = true
//自适应高度
textView.autoresizingMask = UIViewAutoresizing.FlexibleHeight
//设置富文本
var attributeString:NSMutableAttributedString=NSMutableAttributedString(string: "经常听到:\n 被中介骗了,押金不退,晚一天交房租,被讹了。\n\n租房普遍现象:\n网上报价不真实?经常被忽悠!(看房时报价都比网上高!)\n证件不齐全,被骗过!(其实根本不是房东啦!)\n看房前态度都很热情!\n签约之后态度骤变!\n入住后家电维修只能靠自己!\n房屋到期,押金各种被勒索!\n\n现在开始,你来改变这一切!\n《租房点评》为你而备,租房无忧!\n\n再也不用担心被欺骗,想要知道给你介绍房子的人好不好,《租房点评》告诉你!")
//设置字体颜色
attributeString.addAttribute(NSForegroundColorAttributeName, value: UIColor.greenColor(), range: NSMakeRange(, attributeString.length))
//文本所有字符字体HelveticaNeue-Bold,16号
attributeString.addAttribute(NSFontAttributeName, value: UIFont(name: )!, range: NSMakeRange(, attributeString.length))
//文本0开始5个字符字体HelveticaNeue-Bold,16号
attributeString.addAttribute(NSFontAttributeName, value: UIFont(name: )!, range: NSMakeRange(, ))
//设置字体颜色
attributeString.addAttribute(NSForegroundColorAttributeName, value: UIColor.whiteColor(), range: NSMakeRange(, ))
//设置文字背景颜色
attributeString.addAttribute(NSBackgroundColorAttributeName, value: UIColor.orangeColor(), range: NSMakeRange(, ))
//赋值富文本
textView.attributedText = attributeString
//选中一段文本
textView.becomeFirstResponder()
textView.selectedRange = NSMakeRange(, )
//获取内容整体高度
var height:CGFloat = textView.contentSize.height;
//-------------------------------------------自定义菜单
//定义4个菜单选择
var menuItem1:UIMenuItem = UIMenuItem(title: "分享到微信", action: "shareWXMenu:")
var menuItem2:UIMenuItem = UIMenuItem(title: "分享到微博", action: "shareWBMenu:")
//获取菜单控制器
var menuController:UIMenuController = UIMenuController.sharedMenuController()
menuController.menuItems = [menuItem1,menuItem2]
//-------------------------------------------指定代理
textView.delegate = self
//-------------------------------------------添加通知
//文本框开始编辑时,触发
NSNotificationCenter.defaultCenter().addObserver(self, selector: "textDidBeginEditing", name: UITextViewTextDidBeginEditingNotification, object: nil)
//文本框编辑结束时,触发
NSNotificationCenter.defaultCenter().addObserver(self, selector: "textDidEndEditing", name: UITextViewTextDidEndEditingNotification, object: nil)
//文本框内容改变时,触发
NSNotificationCenter.defaultCenter().addObserver(self, selector: "textDidChange", name: UITextViewTextDidChangeNotification, object: nil)
二:相应方法和代理方法的实现
func textDidBeginEditing()
{
println("开始输入文本...")
}
func textDidEndEditing()
{
println("结束输入...")
}
func textDidChange()
{
println("正在输入...")
}
/*
// MARK: - Navigation
// In a storyboard-based application, you will often want to do a little preparation before navigation
override func prepareForSegue(segue: UIStoryboardSegue!, sender: AnyObject!) {
// Get the new view controller using segue.destinationViewController.
// Pass the selected object to the new view controller.
}
*/
// MARK: - UITextFieldDelegate
func textViewShouldBeginEditing(textView: UITextView) -> Bool
{
return true //如果返回false,文本视图不能编辑
}
func textViewShouldEndEditing(textView: UITextView) -> Bool
{
return true //如果返回false,表示编辑结束之后,文本视图不可再编辑
}
func textViewDidBeginEditing(textView: UITextView)
{
//文本视图开始编辑,这个时候我们可以处理一些事情
}
func textViewDidEndEditing(textView: UITextView)
{
//文本视图编辑结束,这个时候我们可以处理一些事情
}
func textView(textView: UITextView, shouldChangeTextInRange range: NSRange, replacementText text: String) -> Bool
{
//文本视图内容改变时,触发本方法,能得到改变的坐标和改变的内容
//如果是回车符号,则textView释放第一响应值,返回false
if (text == "\n") {
textView.resignFirstResponder()
return false;
}
return true
}
func textViewDidChange(textView: UITextView)
{
//文本视图改变后触发本代理方法
}
func textViewDidChangeSelection(textView: UITextView)
{
//文本视图 改变选择内容,触发本代理方法
}
//@availability(iOS, introduced=7.0)
func textView(textView: UITextView, shouldInteractWithURL URL: NSURL, inRange characterRange: NSRange) -> Bool
{
//链接在文本中显示。当链接被点击的时候,会触发本代理方法
return true
}
//@availability(iOS, introduced=7.0)
func textView(textView: UITextView, shouldInteractWithTextAttachment textAttachment: NSTextAttachment, inRange characterRange: NSRange) -> Bool
{
//文本视图允许提供文本附件,文本附件点击时,会触发本代理方法
return true
}
//按钮显示方法
override func canPerformAction(action: Selector, withSender sender: AnyObject?) -> Bool {
//判断有没有选中文字,
//如果选择,输出选择的文本
if(action == "shareWXMenu:" && isSelect)//选择文本,并点击分享到微信菜单
{
return true;
}
else if(action == "shareWBMenu:" && isSelect)//选择文本,并点击分享到微博菜单
{
return true;
}
return false; //不显示系统的菜单,改成true对比一下效果
}
//分享到微信
func shareWXMenu(sender: AnyObject?)
{
{
println((textView.text as NSString).substringWithRange(textView.selectedRange))
}
println("这里实现 分享到微信 功能")
}
//分享到微博
func shareWBMenu(sender: AnyObject?)
{
println("这里实现 分享到微博 功能")
}
iOS开发——UI篇Swift篇&UITextView的更多相关文章
- iOS开发——技术精华Swift篇&Swift 2.0和Objective-C2.0混编之第三方框架的使用
swift 语言是苹果公司在2014年的WWDC大会上发布的全新的编程语言.Swift语言继承了C语言以及Objective-C的特性,且克服了C语言的兼容性问题.Swift语言采用安全编程模式,且引 ...
- iOS开发——新特性Swift篇&Swift 2.0 异常处理
Swift 2.0 异常处理 WWDC 2015 宣布了新的 Swift 2.0. 这次重大更新给 Swift 提供了新的异常处理方法.这篇文章会主要围绕这个方面进行讨论. 如何建造异常类型? 在 i ...
- iOS开发——UI精选OC篇&UIApplication,UIWindow,UIViewController,UIView(layer)简单介绍
UIApplication,UIWindow,UIViewController,UIView(layer)简单介绍 一:UIApplication:单例(关于单例后面的文章中会详细介绍,你现在只要知道 ...
- iOS开发——网络编程Swift篇&Alamofire详解
Alamofire详解 预览图 Swift Alamofire 简介 Alamofire是 Swift 语言的 HTTP 网络开发工具包,相当于Swift实现AFNetworking版本. 当然,AF ...
- ios开发——实用技术总结Swift篇&swift常用开发技术总结
swift常用开发技术总结 懒加载:属性,数组(字典),控件... 数组(懒加载): lazy var shops:Array<Dictionary<String, String>& ...
- iOS开发——网络编程Swift篇&(八)SwiftyJSON详解
SwiftyJSON详解 最近看了一些网络请求的例子,发现Swift在解析JSON数据时特别别扭,总是要写一大堆的downcast(as?)和可选(Optional),看?号都看花了.随后发现了这个库 ...
- ios开发——实用技术篇Swift篇&地址薄、短信、邮件
//返回按钮事件 @IBAction func backButtonClick() { self.navigationController?.popViewControllerAnimated(tru ...
- iOS开发——图形编程Swift篇&CAShapeLayer实现圆形图片加载动画
CAShapeLayer实现圆形图片加载动画 几个星期之前,Michael Villar在Motion试验中创建一个非常有趣的加载动画. 下面的GIF图片展示这个加载动画,它将一个圆形进度指示器和圆形 ...
- iOS开发零基础--Swift篇 元组
元组的介绍 元组是Swift中特有的,OC中并没有相关类型 它是什么呢? 它是一种数据结构,在数学中应用广泛 类似于数组或者字典 可以用于定义一组数据 组成元组类型的数据可以称为“元素” 元组的定义 ...
- iOS开发零基础--Swift篇 循环
循环的介绍 在开发中经常会需要循环 常见的循环有:for/while/do while. 这里我们只介绍for/while,因为for/while最常见 for循环的写法 最常规写法 // 传统写法 ...
随机推荐
- mysql 经典题目
题目1:实现如下效果 CREATE TABLE IF NOT EXISTS tb_amount( `Id` INT NOT NULL AUTO_INCREMENT, `), `), `Amount` ...
- TLCL中英对照版
TLCL中英文对照阅读网址:http://billie66.github.io/TLCL/book/index.html 感谢好奇猫团队(http://haoqicat.com/about/team) ...
- BITED-Windows8应用开发学习札记之一:Win8应用开发入门
基于WinRT的Metro应用是我对Windows8的第一印象,简洁方块配以简单色调真的有沁人心脾的美感. 非常幸运,BITED在这个暑假的这个小学期里有幸学习到一门课程:软件工程基础实践,老师邀请了 ...
- pybombs 安装
参考:https://github.com/gnuradio/pybombs 先装:pip 然后: pip install PyBOMBS 更新源: pybombs recipes add gr-re ...
- RVM 安装&下载Ruby
1. #查看当前ruby版本 2. $ ruby -v 3. ruby 1.8.7 4. #列出已知的ruby版本 5. $ rvm list known 6. #安装ruby 1.9.3 7. $ ...
- APIO2014 爆零总结
真心爆零 不要不服 这次apio给了一种新的赛制 看上去很好? 所有人都可以在线提交 并且实时知道自己的分数 它对每个题目分成若干分数段 每个分数段有若干数据 要获得这个分数段的分数需要通过这个分数段 ...
- Advanced Scene Processing
[How a Scene Processes Frames of Animation] In the traditional view system, the contents of a view a ...
- esb异常20160322_1948
异常1. Failed to find entry point for component, the following resolvers tried but failed: [ 2016-03-2 ...
- UVALive 6692 Lucky Number (思路 + 枚举)
题意:给你n 个数字,某一个数的幸运数是这个数前面比他小 离他最远的位置之差,求出最大幸运值. 析:先按从大到小排序,然后去维护那个最大的id,一直比较,更新最大值就好. 代码如下: #pragma ...
- window 方法:延时 和 重复
window 方法 var timer = setTimeout(closeFunc,10*1000); function closeFunc(){ alert('close'); }