swift开发常用代码片段
// 绑定事件
cell.privacySwitch.addTarget(self, action: #selector(RSMeSettingPrivacyViewController.switchTapped(_:)), for: UIControl.Event.valueChanged) @objc func switchTapped(_ sender: UISwitch) {
print(sender.isOn)
} // 跳转页面
var targetVc: UIViewController
targetVc = targetViewController()
navigationController?.pushViewController(targetVc, animated: true) // 导入指定cell
if cell == nil {
cell = Bundle.main.loadNibNamed("cell", owner: nil, options: nil)?.first
} // 隐藏 tableHeaderView
tableView.tableHeaderView?.removeFromSuperview()
tableView.tableHeaderView = UIView(frame: CGRect(x: , y: , width: , height: CGFloat.leastNonzeroMagnitude)) // 隐藏 presentView
self.presentingViewController?.dismiss(animated: true, completion: nil) // 创建 button
lazy private var logoutButton: UIButton = {
let logoutButton = UIButton()
logoutButton.setTitle("退出登录", for: .normal)
logoutButton.titleLabel?.font = UIFont.systemFont(ofSize: )
// 文字加粗
// submitButton.titleLabel?.font = UIFont.boldSystemFont(ofSize: 16)
logoutButton.setTitleColor(UIColor.rs_purple_8127fd, for: .normal)
logoutButton.addTarget(self, action: #selector(logoutButtonTapped), for: UIControl.Event.touchUpInside) // 添加阴影
logoutButton.layer.shadowOpacity = 0.8
logoutButton.layer.showColor = UIColor.black.cgColor
logoutButton.layer.shadowOffset = CGSize(width: , height: )
logoutButton.clipsToBounds = false // 这行一定要加,而且得加载最后,不然阴影没有效果
return logoutButton
}() // 在 viewDidLoad() 中
view.addSubview(logoutButton)
logoutButton.snp.makeConstraints { make in
make.height.equalTo()
make.width.equalTo()
make.bottom.equalTo(self.bottomLayoutGuide.snp.top).offset(-)
make.centerX.equalToSuperview()
} // alert 弹框
let alertController = UIAlertController(title: "提示", message: "xxx", preferredStyle: .alert)
let cancelAction = UIAlertAction(title: "取消", style: .cancel, handler: { action in
cell.privacySwitch.setOn(true, animated: true) })
let okAction = UIAlertAction(title: "好的", style: .default, handler: { action in
cell.privacySwitch.setOn(false, animated: true) })
alertController.addAction(cancelAction)
alertController.addAction(okAction)
// 显示 alert
self.present(alertController, animated: true, completion: nil) //action sheet
lazy var actionSheet: UIAlertController = {
let actionSheet = UIAlertController(title: "提示", message: "some info...",
preferredStyle: .actionSheet)
let muteAction = UIAlertAction(title: "不看", style: .default, handler: nil)
let unFollowAction = UIAlertAction(title: "取消关注", style: .default, handler: nil)
let deleteAction = UIAlertAction(title: "举报", style: .destructive, handler: nil)
let cancelAction = UIAlertAction(title: "取消", style: .cancel, handler: nil)
actionSheet.addAction(muteAction)
actionSheet.addAction(unFollowAction)
actionSheet.addAction(deleteAction)
actionSheet.addAction(cancelAction)
return actionSheet
}() // 显示 action sheet
self.present(self.actionSheet, animated: true, completion: nil) // 导航栏添加按钮
let submitButton = UIBarButtonItem(title: "提交", style: .plain, target: self, action: #selector(submitButtonTapped))
self.navigationItem.rightBarButtonItem = submitButton @objc func submitButtonTapped() {
print("点击了提交...")
} // 导航栏按钮禁用
self.navigationItem.rightBarButtonItem?.isEnabled = false // 隐藏导航栏
self.navigationController?.setNavigationBarHidden(true, animated: true) // textView 限制字数
lazy private var textView: UITextView = {
let textView = UITextView(frame: CGRect.zero)
textView.delegate = self
textView.text = "输入文字..."
return textView
}() extension RSSettingFeedbackViewController: UITextViewDelegate {
func textViewDidChange(_ textView: UITextView) {
// 限制字数
if textView.text.count >= {
textView.text = String(textView.text.prefix())
}
}
} // 拍照或从图库选择图片
// 上传照片
// uploadButton action: uploadButtonTapped
func uploadButtonTapped() {
let picker = UIImagePickerController()
picker.delegate = self
picker.allowsEditing = true var sourceType = UIImagePickerController.SourceType.camera
if !UIImagePickerController.isSourceTypeAvailable(sourceType) {
sourceType = UIImagePickerController.SourceType.photoLibrary
}
picker.sourceType = sourceType
self.present(picker, animated: true, completion: nil)
} // 获取当前拍摄或选择的照片
func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) {
if let photo = info[UIImagePickerController.InfoKey.editedImage] as? UIImage {
let image = UIImageView.init(frame: self.view.frame)
image.image = photo
uploadButton.setImage(photo, for: UIControl.State.normal)
}
picker.dismiss(animated: true, completion: nil)
} // cancel后执行的方法
func imagePickerControllerDidCancel(_ picker: UIImagePickerController) {
picker.dismiss(animated: true, completion: nil)
} // 打开连接(页面跳转)
let str = NSString(format: "itms-apps://itunes.apple.com/app/id%@?action=write-review", VendorConfig.tagAPPID)
UIApplication.shared.openURL(NSURL(string: str as String)! as URL) // 一个搜索框
lazy var textField: UITextField = {
let textField = UITextField(frame: CGRect.zero)
let leftView = UIImageView(image: UIImage(named: "release_search")?.withRenderingMode(UIImage.RenderingMode.alwaysOriginal))
textField.leftView = leftView
textField.leftViewMode = .always
leftView.contentMode = .center
leftView.frame = CGRect(x: , y: , width: , height: )
textField.clearButtonMode = .whileEditing
textField.placeholder = "搜索..."
textField.backgroundColor = UIColor.rs_gray_f2f2f2
textField.font = UIFont.rs_pingfangsc_regular(size: )
textField.cornerRadius =
textField.delegate = self
return textField
}() // 添加分隔线
let topLine = UIView()
topLine.backgroundColor = UIColor.rs_gray_d8d8d8 topLine.snp.makeConstraints { (make) in
make.left.equalTo()
make.right.equalTo(-)
make.top.equalTo(addressCell.snp.top).offset(-)
make.height.equalTo( / kScale)
} // tableview 去除边框线
tableView.separatorStyle = UITableViewCell.SeparatorStyle.none // 添加阴影 —— xib 中添加 shadow
targetView.clipsToBounds = false // 根据屏幕宽度计算图片展示高度
let scale = finalImage.size.height / finalImage.size.width
self.collectionView.snp.makeConstraints { (make) in
make.left.right.equalToSuperview()
make.top.equalTo(self.tipLabel.snp.bottom).offset()
make.height.equalTo(self.view.snp.width).multipliedBy(scale)
} // 给视图添加手势(点击、双击)
// 单击切换音量控制
let singleTap = UITapGestureRecognizer(target: self, action: #selector(changeVolumeStatus))
singleTap.numberOfTapsRequired =
// 双击点赞
let doubleTap = UITapGestureRecognizer(target: self, action: #selector(handleDoubleTap))
doubleTap.numberOfTapsRequired = // 优先检测双击手势
singleTap.require(toFail: doubleTap) // 将手势添加到视图
targetView.addGestureRecognizer(singleTap)
targetView.addGestureRecognizer(doubleTap) // 使用 AVPlayer 播放视频
import AVFoundation
/// 播放器
lazy var avplayLayer: AVPlayerLayer = {
let avplayLayer = AVPlayerLayer(player: nil)
avplayLayer.videoGravity = .resizeAspectFill
return avplayLayer
}() let url = URL(string: "http://pri-video.v.medlinker.net/5595b16d-72bc-4fcb-bef2-c01327abeab3/10.m3u8")
avplayLayer.player = AVPlayer(url: url!)
let scale = CGFloat(video.wide / video.high)
// 通过视频和容器尺寸计算最终展示尺寸
momentContentHeightConstraint?.update(offset: (kScreenWidth - ) / scale)
avplayLayer.frame = CGRect(x: , y: , width: kScreenWidth - , height: (kScreenWidth - ) / scale)
avplayLayer.player?.play() // tableView 设置背景 // 默认拉伸撑满 tableview
self?.tableView.backgroundView = UIImageView.init(image: UIImage(named: "no_feed")) // 图片原始尺寸位于 tableview 中央
let bg = UIImageView.init(image: UIImage(named: "no_feed"))
bg.contentMode = .center
self?.tableView.backgroundView = bg // 子线程执行代码
DispatchQueue.cwl_mainThreadAsync {
let cell = self.cacheCell as? RSSettingAccountCell
cell!.formItemValue.text = String(self.fileSizeOfCache()) + "Mb"
stopLoading()
let feedbackAlert = UIAlertController(title: nil, message: "清除成功!", preferredStyle: .alert)
self.present(feedbackAlert, animated: true, completion: nil)
Timer.scheduledTimer(timeInterval: 1.5, target: self, selector: #selector(self.hideAlert), userInfo: nil, repeats: false)
} // tableview 隐藏滚动条
tableView.showsVerticalScrollIndicator = false
swift开发常用代码片段的更多相关文章
- 36个Android开发常用代码片段
//36个Android开发常用代码片段 //拨打电话 public static void call(Context context, String phoneNumber) { context.s ...
- Android开发常用代码片段
拨打电话 public static void call(Context context, String phoneNumber) { context.startActivity( new Inten ...
- C#常用代码片段备忘
以下是从visual studio中整理出来的常用代码片段,以作备忘 快捷键: eh 用途: 类中事件实现函数模板 private void MyMethod(object sender, Event ...
- Vue3.0常用代码片段和开发插件
Vue3 Snippets for Visual Studio Code Vue3 Snippets源码 Vue3 Snippets下载 This extension adds Vue3 Code S ...
- 56个PHP开发常用代码
2016/02/14 6203 4 在编写代码的时候有个神奇的工具总是好的!下面这里收集了 50+ PHP 代码片段,可以帮助你开发 PHP 项目. 这些 PHP 片段对于 PHP 初学者也非常 ...
- iOS开发-代码片段(Code Snippets)提高开发效率
简介 在 XCode4 引入了一个新特性,那就是“代码片段(Code Snippets)”.对于一些经常用到的代码,抽象成模板放到 Code Snippets 中,使用的时候就只需要键入快捷键就可以了 ...
- Jquery学习总结(1)——Jquery常用代码片段汇总
1. 禁止右键点击 ? 1 2 3 4 5 $(document).ready(function(){ $(document).bind("contextmenu",fun ...
- jQuery常用代码片段
检测IE浏览器 在进行CSS设计时,IE浏览器对开发者及设计师而言无疑是个麻烦.尽管IE6的黑暗时代已经过去,IE浏览器家族的人气亦在不断下滑,但我们仍然有必要对其进行检测.当然,以下片段亦可用于检测 ...
- Swift开发常用知识点
#pragma mark - as/类型转换as? / as! 需要根据前面的返回值决定 有?证明可选,可能为空:需要弱解包 没有?证明一定有值:大胆解包 as? 前面的结果是可选的 if let / ...
随机推荐
- .net web 应用程序C#
简介 开发环境:VS2015 ASP.NET:可以开发出几乎所有运行在Windows上的应用程序:.NET是一种架构,一种新的API:引入程序集代替DLL: ADO.NET:一组.NET组件提供对数据 ...
- 软工实践-Alpha 冲刺 (10/10)
队名:起床一起肝活队 组长博客:博客链接 作业博客:班级博客本次作业的链接 组员情况 组员1(队长):白晨曦 过去两天完成了哪些任务 描述: 完成所有界面的链接,整理与测试 展示GitHub当日代码/ ...
- 周总结<1>
由于都不清楚周总结的格式,所以就没有写了.不过,上次听了老师的课,觉得应该要好好写写了,至少今后可以明白自己有做过什么事情,至少不会觉得自己在各个方面没有收获.不过,可能没有按照格式来写.希望老师体谅 ...
- POJ题目分类推荐 (很好很有层次感)
著名题单,最初来源不详.直接来源:http://blog.csdn.net/a1dark/article/details/11714009 OJ上的一些水题(可用来练手和增加自信) (POJ 3299 ...
- linux 虚拟网络模型介绍
第一种隔离模型 每一个虚拟机实例的网卡都有两个接口,一端接在虚拟机内部,一端接在宿主机内部,如上图所示eth0就是接在虚拟机内部的,而vnet0就是接在宿主机内部的,只要再创建一个虚 ...
- 安恒杯-babysql
1. 库名 ?id= and extractvalue(,(select group_concat(0x3a,schema_name) from information_schema.schemata ...
- SpringMVC源码剖析(五)-消息转换器HttpMessageConverter
原文链接:https://my.oschina.net/lichhao/blog/172562 #概述 在SpringMVC中,可以使用@RequestBody和@ResponseBody两个注解,分 ...
- 中国省市 Json 二级联动
Json数据: var cities = {'北京': ['北京'], '广东': ['广州', '深圳', '珠海', '汕头', '韶关', '佛山', '江门', '湛江', '茂名', '肇庆 ...
- 【BZOJ2138】stone(线段树,Hall定理)
[BZOJ2138]stone(线段树,Hall定理) 题面 BZOJ 题解 考虑一个暴力. 我们对于每堆石子和每个询问,显然是匹配的操作. 所以可以把石子拆成\(a_i\)个,询问点拆成\(K_i\ ...
- NOI2014魔法森林题解报告
题目描述 为了得到书法大家的真传,小 E 同学下定决心去拜访住在魔法森林中的隐 士.魔法森林可以被看成一个包含 n 个节点 m 条边的无向图,节点标号为 1,2,3,-,n,边标号为 1,2,3,-, ...