热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

swift语言IOS8开发战记19UIImagePickerController

我们接着上一话的内容来讲,首先在我们添加一个餐馆的页面中把点击的背景色取消掉使用的是以下语句:cell.selectionStyleUITableViewCellSelectionStyle

  我们接着上一话的内容来讲,首先在我们添加一个餐馆的页面中把点击的背景色取消掉使用的是以下语句:

cell.selectiOnStyle= UITableViewCellSelectionStyle.None

除了none之外,还有许多颜色的选项,大家可以自己试试。然后我们需要点击小相机的图片能打开我们的相册让我们选择图片,我们在选择的代理方法中增加一个我们自己定义的方法,代码如下:

func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {//点击行的代理方法
var row:NSInteger = indexPath.row
if row == 0{
self.didClickedImageView()
}
下面是didClickedImageView的代码:
func didClickedImageView(){
let imagePicker = UIImagePickerController() //选择图片
let isAvailable = UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.Camera)
imagePicker.sourceType = .PhotoLibrary
if isAvailable {
imagePicker.sourceType = .Camera
}
self.presentViewController(imagePicker, animated: true, completion: nil)
}

点击小相机的图标显示如下:


现在我们希望我们选择了照片之后可以把该照片保存到第一行之中,这就需要在点击第一行的时候把当前的类当做imagePicker的代理,所以把点击第一行所触发的方法didClickedImageView修改如下:

func didClickedImageView(){
let imagePicker = UIImagePickerController() //选择图片
let isAvailable = UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.Camera)
imagePicker.sourceType = .PhotoLibrary
imagePicker.delegate = self//代理设为自己
if isAvailable {
imagePicker.sourceType = .Camera
}
self.presentViewController(imagePicker, animated: true, completion: nil)
}

imagePicker是UIImagePickerController类型的,要实现这个类型的代理,必须继承
UINavigationControllerDelegateUIImagePickerControllerDelegate,然后我们实现代理方法imagePickerController用来保存我们选择的图片,代码如下:

 func imagePickerController(picker: UIImagePickerController!, didFinishPickingImage image: UIImage!, editingInfo: [NSObject : AnyObject]!) {//保存图片
imageView.image = image
picker.dismissViewControllerAnimated(true, completion: nil)
}

在选中图片后,效果如图



接下来我们来实现下面这几行,代码如下:

 func configureCell(cell:UITableViewCell, indexPath: NSIndexPath){
let row:NSInteger = indexPath.row
var nameLabel = UILabel(frame: CGRectMake(10, 5, 200, 15))
switch row{
case 0:
imageView = UIImageView(frame: CGRectMake(0, 0, 320, 250))
imageView.image = UIImage(named: "camera")
imageView.cOntentMode= UIViewContentMode.ScaleAspectFit
cell.addSubview(imageView)
case 1:
nameLabel.text = "Name"
cell.addSubview(nameLabel)
var textFiled = UITextField(frame: CGRectMake(10, 20, 250, 40))
textFiled.placeholder = "Restaurant Name"
cell.addSubview(textFiled)
case 2:
nameLabel.text = "Type"
cell.addSubview(nameLabel)
var textFiled = UITextField(frame: CGRectMake(10, 20, 250, 40))
textFiled.placeholder = "Restaurant Type"
cell.addSubview(textFiled)

case 3:
nameLabel.text = "Location"
cell.addSubview(nameLabel)
var textFiled = UITextField(frame: CGRectMake(10, 20, 250, 40))
textFiled.placeholder = "Restaurant Location"
cell.addSubview(textFiled)
default:
nameLabel.text = "Have you been here?"
cell.addSubview(nameLabel)


}
}
结构都比较相似,我们把之前的if结构改成了switch,UITextFiled有一个属性placeholder,实现了水印字体的效果,效果如下:

在最后一栏中需要加两个按钮,一个YES和一个NO,然后再导航栏中增加一个标题,NewViewController的完整代码如下:

import UIKit

class NewViewController: UIViewController,UITableViewDataSource,UITableViewDelegate,UINavigationControllerDelegate,UIImagePickerControllerDelegate {
let identifier = "newCell"
var imageView:UIImageView!
override func viewDidLoad() {
super.viewDidLoad()
self.view.backgroundColor = UIColor.orangeColor()

//增加一个tableview
var tableView = UITableView(frame: self.view.bounds, style: .Plain)
tableView.dataSource = self
tableView.delegate = self
tableView.registerClass(UITableViewCell.self, forCellReuseIdentifier: "newCell")
self.view.addSubview(tableView)
self.navigationItem.title = "New Restaurant"

}
func numberOfSectionsInTableView(tableView: UITableView) -> Int {
return 1
}
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return 5
}
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {

let cell = UITableViewCell(style: .Default, reuseIdentifier: "newCell")
self.configureCell(cell, indexPath: indexPath)
cell.selectiOnStyle= UITableViewCellSelectionStyle.None//选中的背景色
return cell
}
func tableView(tableView: UITableView, heightForRowAtIndexPath indexPath: NSIndexPath) -> CGFloat {
var row:NSInteger = indexPath.row
var rowHeight:CGFloat = 62
if row == 0
{
rowHeight = 250
}
return rowHeight
}
func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
var row:NSInteger = indexPath.row
if row == 0{
self.didClickedImageView()
}
}

func configureCell(cell:UITableViewCell, indexPath: NSIndexPath){
let row:NSInteger = indexPath.row
var nameLabel = UILabel(frame: CGRectMake(10, 5, 200, 15))
switch row{
case 0:
imageView = UIImageView(frame: CGRectMake(0, 0, 320, 250))
imageView.image = UIImage(named: "camera")
imageView.cOntentMode= UIViewContentMode.ScaleAspectFit
cell.addSubview(imageView)
case 1:
nameLabel.text = "Name"
cell.addSubview(nameLabel)
var textFiled = UITextField(frame: CGRectMake(10, 20, 250, 40))
textFiled.placeholder = "Restaurant Name"
cell.addSubview(textFiled)
case 2:
nameLabel.text = "Type"
cell.addSubview(nameLabel)
var textFiled = UITextField(frame: CGRectMake(10, 20, 250, 40))
textFiled.placeholder = "Restaurant Type"
cell.addSubview(textFiled)

case 3:
nameLabel.text = "Location"
cell.addSubview(nameLabel)
var textFiled = UITextField(frame: CGRectMake(10, 20, 250, 40))
textFiled.placeholder = "Restaurant Location"
cell.addSubview(textFiled)
default:
nameLabel.text = "Have you been here?"
cell.addSubview(nameLabel)
var leftBtn = UIButton(frame: CGRectMake(10, 30, 50, 25))
leftBtn.setTitle("YES", forState: .Normal)
leftBtn.setTitleColor(UIColor.whiteColor(), forState: .Normal)
leftBtn.backgroundColor = UIColor.redColor()
cell.addSubview(leftBtn)
var rightBtn = UIButton(frame: CGRectMake(90, 30, 50, 25))
rightBtn.setTitle("NO", forState: .Normal)
rightBtn.setTitleColor(UIColor.whiteColor(), forState: .Normal)
rightBtn.backgroundColor = UIColor.grayColor()
cell.addSubview(rightBtn)

}
}

func didClickedImageView(){
let imagePicker = UIImagePickerController() //选择图片
let isAvailable = UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.Camera)
imagePicker.sourceType = .PhotoLibrary
imagePicker.delegate = self
if isAvailable {
imagePicker.sourceType = .Camera
}
self.presentViewController(imagePicker, animated: true, completion: nil)
}

func imagePickerController(picker: UIImagePickerController!, didFinishPickingImage image: UIImage!, editingInfo: [NSObject : AnyObject]!) {//保存图片
imageView.image = image
picker.dismissViewControllerAnimated(true, completion: nil)
}

}





推荐阅读
  • 本文介绍了iOS数据库Sqlite的SQL语句分类和常见约束关键字。SQL语句分为DDL、DML和DQL三种类型,其中DDL语句用于定义、删除和修改数据表,关键字包括create、drop和alter。常见约束关键字包括if not exists、if exists、primary key、autoincrement、not null和default。此外,还介绍了常见的数据库数据类型,包括integer、text和real。 ... [详细]
  • 开发笔记:实验7的文件读写操作
    本文介绍了使用C++的ofstream和ifstream类进行文件读写操作的方法,包括创建文件、写入文件和读取文件的过程。同时还介绍了如何判断文件是否成功打开和关闭文件的方法。通过本文的学习,读者可以了解如何在C++中进行文件读写操作。 ... [详细]
  • 本文讨论了在手机移动端如何使用HTML5和JavaScript实现视频上传并压缩视频质量,或者降低手机摄像头拍摄质量的问题。作者指出HTML5和JavaScript无法直接压缩视频,只能通过将视频传送到服务器端由后端进行压缩。对于控制相机拍摄质量,只有使用JAVA编写Android客户端才能实现压缩。此外,作者还解释了在交作业时使用zip格式压缩包导致CSS文件和图片音乐丢失的原因,并提供了解决方法。最后,作者还介绍了一个用于处理图片的类,可以实现图片剪裁处理和生成缩略图的功能。 ... [详细]
  • 本文介绍了在iOS开发中使用UITextField实现字符限制的方法,包括利用代理方法和使用BNTextField-Limit库的实现策略。通过这些方法,开发者可以方便地限制UITextField的字符个数和输入规则。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • Redis底层数据结构之压缩列表的介绍及实现原理
    本文介绍了Redis底层数据结构之压缩列表的概念、实现原理以及使用场景。压缩列表是Redis为了节约内存而开发的一种顺序数据结构,由特殊编码的连续内存块组成。文章详细解释了压缩列表的构成和各个属性的含义,以及如何通过指针来计算表尾节点的地址。压缩列表适用于列表键和哈希键中只包含少量小整数值和短字符串的情况。通过使用压缩列表,可以有效减少内存占用,提升Redis的性能。 ... [详细]
author-avatar
踢出个未来为我鼓掌
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有