Swift Code Block Backups

简单粗暴 不定期更新(始于161128)......

  1. 打开关闭闪光灯
 let device = AVCaptureDevice.defaultDeviceWithMediaType(AVMediaTypeVideo)
 if device.hasTorch {
        do {
             try device.lockForConfiguration()
        } catch _ {
        }
       device.torchMode = AVCaptureTorchMode.On // .Off
       device.unlockForConfiguration()
 }
  1. UISearchBar 去除背景灰色
let searchBar = UISearchBar.init(frame: CGRect(x: 10, y: 5, width: ScreenWidth-70, height: 30))
for subview in searchBar.subviews {
     if subview.isKind(of: NSClassFromString("UIView")!) && subview.subviews.count > 0 {
          subview.subviews.first!.removeFromSuperview()
     }
  }
  1. 某一页隐藏 navigationbar,下一页显示
 override func viewWillAppear(_ animated: Bool) {
      super.viewWillAppear(animated)
      navigationController?.setNavigationBarHidden(true, animated: true)
 }

 override func viewWillDisappear(_ animated: Bool) {
      super.viewWillDisappear(animated)
      navigationController?.setNavigationBarHidden(false, animated: true)
 }
  1. delegate
 protocol NewHomeTopSearchViewDelegate: NSObjectProtocol {
       func topViewBeginSearch()
 }

 class NewHomeTopSearchView: UIView, UISearchBarDelegate {
      var delegate: NewHomeTopSearchViewDelegate?
    
      func searchBarTextDidBeginEditing(_ searchBar: UISearchBar) {
          if let delegate = delegate {
              delegate.topViewBeginSearch()
          }
       }
 }
  1. SnapKit 是 Masonry 的 Swift 版本,资源地址:MasonrySnapKit
    基本用法如下:
myPointLabel.snp.makeConstraints { (make) 
       make.top.equalTo(signButton.snp.top).offset(20)
       make.height.equalTo(signButton)
       make.left.equalToSuperview()
       make.right.equalTo(signButton.snp.left).offset(-10)
 }
  1. button 整体位置
button.contentHorizontalAlignment = UIControlContentHorizontalAlignment.left
button.contentVerticalAlignment = UIControlContentVerticalAlignment.top
  1. 类方法
class func newHomeGetItemHeight(ratioWidth: CGFloat, ratioHegiht: CGFloat, width: CGFloat) -> CGFloat {
        return width * ratioHegiht / ratioWidth
    }
  1. 碰到了一个约束的问题:依据 屏幕w 动态适应了 itemH,但是由于 item 中 仅仅按照比例设置了 imgView的宽高,又由于 按比例计算了itemH,那么在不同的尺寸下(SE),imgView 与 item 动态的改变了 H,但是其他的控件的高度没变,所以其他控件就不正常的显示了 ---> 解决:如果需要按照比例设置item,那么应该给 item中的 每个控件 都添加比例约束
    xib中 单个控件 按比例设置宽高约束:xib中固定好相对位置(比如 设置好上左右约束后 手动设置正确的高度,然是不要把高度加入约束中,而是图8-0) -> 按比例设置好宽高,但不要添加到约束中 - 图8-0
图8-0

图8-1

图8-2
  1. appdelegate 获取 storyboard 创建的 UITabBarController
let tabbarVC = self.window?.rootViewController as! UITabBarController
tabbarVC.tabBar.tintColor = UIColor.init(rgb: 0xFF2832)
  1. 修改状态栏的背景色
extension UIApplication {
      var statusBarView: UIView? {
          return value(forKey: "statusBar") as? UIView
      }
}  
UIApplication.shared.statusBarView?.backgroundColor = .red
  1. 当 vc 在 nvc 中的时候,需要更改状态栏颜色
// 状态栏字体为白色,状态栏和导航栏背景为黑色 
self.navigationController?.navigationBar.barStyle = .black
// 状态栏字体为黑色,状态栏和导航栏背景为白色
self.navigationController?.navigationBar.barStyle = .default
  1. 获取文字的宽高
    override func viewDidLayoutSubviews() {
        super.viewDidLayoutSubviews()

        let text = name_label.text! as NSString

        let length = text.boundingRect(with: CGSize.init(width: CGFloat.greatestFiniteMagnitude, height: 15), options: .usesLineFragmentOrigin, attributes: [NSFontAttributeName : name_label.font], context: nil).size.width + 1

        name_label.snp.remakeConstraints { (make) in
            make.top.equalTo(41)
            make.width.equalTo(length)
            make.height.equalTo(15)
            make.left.equalTo(avatarImgView.snp.right).offset(25)
        }

    }
  1. 获取空间最大y
signature_label.frame.maxY
  1. 初始化一个存放 label 的数组
private var label_array = Array<UILabel>()
  1. 获取当前日期为星期几
        var calendar = NSCalendar.current

        calendar.timeZone = TimeZone.init(identifier: "Asia/Shanghai")!

        let components = calendar.component(.weekday, from: Date.init())

        print(components)
  1. 判断点击区域
    override func touchesEnded(_ touches: Set<UITouch>, with event: UIEvent?) {
        let touch = (touches as NSSet).anyObject() as! UITouch

        let point = touch.location(in: self.view)

        if !self.collectionView.frame.contains(point) {

            self.navigationController?.popViewController(animated: true)
        }
    }
  1. 某一个vc 隐藏 statusbar
override var prefersStatusBarHidden: Bool {

        return true
    }
  1. 转 str 并保留两位小数
String.init(format: "%.2f", doublevalue)
  1. UIKeyboardWillChangeFrame
 NotificationCenter.default.addObserver(self, selector: #selector(keybordChanged), name: .UIKeyboardWillChangeFrame, object: nil)
  1. 图片拉伸
private lazy var bgImgView: UIImageView = {
        var image = UIImage.init(named: "r_beijing")
        image = image?.stretchableImage(withLeftCapWidth: Int((image?.size.width)!/2.0), topCapHeight: Int((image?.size.height)!/2.0))

        let imgView = UIImageView.init()
        imgView.image = image
        imgView.isUserInteractionEnabled = true
        return imgView
    } ()

 不定期更新 不合适的地方 还请指点~ 感激不尽
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,761评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,953评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,998评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,248评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,130评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,145评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,550评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,236评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,510评论 1 291
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,601评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,376评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,247评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,613评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,911评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,191评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,532评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,739评论 2 335

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 11,947评论 4 60
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,073评论 25 707
  • 我的世界没有荣华富贵也不是贫瘠不堪,至于生活的味道,不过恰到好处。 世界的路很多都是相同的——通往为名为利的道路。...
    知识分享阅读 403评论 0 0
  • 第一次授勋仪式第一次授勋因为一些原因推迟到2月5日,前一天晚上问桐桐想让谁授勋,她说想让爸爸参加,让妈妈拍照。和很...
    冯瑾2017阅读 317评论 0 0
  • 《我的前半生》中的贺涵,大家都认为他是“理想”超人,希望自己身边有一个这样的人,帮助自己,成就自己。想法很好,理想...
    闫海涛老师阅读 227评论 0 0