小BUG、问题、总结

2016-06-24  本文已影响122人  四月_Hsu
6月24日
  1. 改变状态栏文字颜色,即时间、电池等的颜色:
首先, 在 plist 文件中添加  View controller-based status bar appearance ,并将其设置为 NO 。
 然后, 在需要修改的页面的 `super.viewDidLoad()` 下面添加 UIApplication.sharedApplication().statusBarStyle = .LightContent  即可。
⚠️ 注意,这个操作会改变前后页的文字颜色。如果不同的页面不同展示,那么就改变 `style` 的值。
6月27日
  1. 当我们使用定位服务的时候,发现 CLLocationManagerDelegate 方法不执行,是因为我们没有授权定位。解决办法(注意,这两个字段在plist文件中中是找不到的,需要手动输入):
首先在 info.plist里加入对应的缺省字段 ,值设置为YES(前台定位写上边字段,前后台定位写下边字段)         
NSLocationWhenInUseDescription             //  使用时获取定位
NSLocationWhenInUseUsageDescription        // 允许在前台获取GPS的描述 
NSLocationAlwaysUsageDescription           // 允许在前、后台获取GPS的描述 

说明一下上面三个字段使用时的区别:NSLocationWhenInUseDescription 是最常用的一个设置,此时将字段 NSLocationAlwaysUsageDescription 设置为 String 类型,并加入描述文字,首次使用APP时,在使用定位的弹框提示中,下面小字显示自己的描述文字。NSLocationWhenInUseUsageDescription 字段设置为 Bool 值时,使用程序期间将程序后台运行,会再手机最上方提示自己的APP正在使用定位服务。NSLocationAlwaysUsageDescription 表示APP使用使用定位服务。这个在上传到AppStore审核时,必须要说明程序在哪里使用了实时定位服务,并且要说明实时定位会损耗电池寿命。

7月6日
  1. 获取本地视频的指定时间截图

首先,获取安装路径下 Documents 文件夹路径,并且遍历所有文件,获取完整路径:

/**
     获取全部视频了路径
     - returns: 路径数组
     */
    func getAllVideoPaths() -> [String] {
        var pathArray = [String]()
        //  Documents 文件夹
        let pathFolder = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)
        //  文件夹路径
        let pathString = pathFolder[0] as String
        //  拼接获取每一个文件的完整路径
        if let lists =  try? NSFileManager.defaultManager().contentsOfDirectoryAtPath(pathString) {
            for item in lists {
                pathArray.append(pathString + "/" + item)
            }
        }
        return pathArray
    }

然后根据路径获取封面:

  //  通过文件路径获取截图:
    func getVideoImage(videoUrl: NSURL) -> UIImage? {
        //  获取截图
        let videoAsset = AVURLAsset(URL: videoUrl)
        let cmTime = CMTime(seconds: 1, preferredTimescale: 10)
        let imageGenerator = AVAssetImageGenerator(asset: videoAsset)
        if let cgImage = try? imageGenerator.copyCGImageAtTime(cmTime, actualTime: nil) {
            let image = UIImage(CGImage: cgImage)
            return image
        } else {
            print("获取缩略图失败")
        }
        return nil
    }

删除指定路径下的文件方法:

        NSFileManager.defaultManager().removeItemAtURL(<#T##URL: NSURL##NSURL#>)
        NSFileManager.defaultManager().removeItemAtPath(<#T##path: String##String#>)
7月11日
  1. 获取设备外网IP的方法:

使用乐视的视频上传功能用到了这个知识点:

  /**
   获取设备外网IP地址
   
   - returns: 地址
   */
  func getDeviceIP() -> NSDictionary? {
      
      let ipUrl = NSURL.init(string: "http://pv.sohu.com/cityjson?ie=utf-8")
      if var needIP = try? String.init(contentsOfURL: ipUrl!, encoding: NSUTF8StringEncoding) {
          //  判断字符串是否是所需数据
          if needIP.hasPrefix("var returnCitySN = ") {
              //  对字符串进行处理,然后进行Json解析,删除字符串多与字符
              for _ in 0 ..< 19 {
                  needIP.removeAtIndex(needIP.startIndex)
              }
              
              //  截取字符串
              let nowIP = needIP.substringToIndex(needIP.startIndex.advancedBy(needIP.characters.count - 1))
              //  将字符串换成二进制进行Json解析
              let data = nowIP.dataUsingEncoding(NSUTF8StringEncoding)
              
              if let needData = try? NSJSONSerialization.JSONObjectWithData(data!, options: NSJSONReadingOptions.MutableContainers) {
                  return needData as? NSDictionary
              } else {
                  print("解析外网地址失败")
                  return nil
              }
          }
      } else {
          print("获取外网地址失败")
      }
      
      return nil
  }
7月12日
  1. 计算指定路径下文件的大小。

计算沙盒内部文件大小时用到这个方法:

        //  文件大小,self.videoUrl 是文件路径
        do {
            let file = try NSFileManager.defaultManager().attributesOfItemAtPath(self.videoUrl!)
            let size = file["NSFileSize"] as! CGFloat
            let fileSize: CGFloat = size / CGFloat(1024) / CGFloat(1024)
            //  保留两位小数
            print("文件大小: \(String(format: "%0.2f",fileSize)) M")
            
        } catch let error as NSError {
            print("error = \(error)")
        }
7月19日
  1. 将标准时间转换为时间串。

2016-07-18 12:26:16 +0000 -> 20160718122616 , 在用乐视SDK上传本地视频的时候用到了这个知识点。需要注意的是标准时间会比目前时间提前8小时,这里也做了简单的转化:

    /**
     将日期转换成年月日时分秒的样式,用于存储本地视频

     - parameter originDate: 需要转换的原始时间
     
     - returns: 成品
     */
    func transformDateToTimeString(originDate: NSDate) -> String {
        
        //  NSDate() 会比现在的时间提前8小时,转换为当前时间
        let zone = NSTimeZone.systemTimeZone()
        let interval = zone.secondsFromGMTForDate(originDate)
        let localDate = originDate.dateByAddingTimeInterval(Double(interval))
        
        //  将日期转化为字符串       "2016-07-18 12:26:16 +0000\n"
        var dateArray = String(localDate).componentsSeparatedByString(" ")
        let first = dateArray.first?.componentsSeparatedByString("-")
        let second = dateArray[1].componentsSeparatedByString(":")
        let firArr: NSMutableArray = NSMutableArray(array: first!)
        let secArr: NSMutableArray = NSMutableArray(array: second)
        let name = firArr.componentsJoinedByString("") + secArr.componentsJoinedByString("")
        return name
        
    }
  1. 将总秒数转换为播放时间。

30 -> 00:00:30 。这里比较有价值的就是字符的格式化输出这个点。

  /**
   将秒数转化为 00:00:00 的时间样式
   
   - parameter totalSecond: 待转换秒数
   
   - returns: 时间
   */
  func mTransformSecondsToPlayTime(totalSecond: Int?) -> String {
      if let seconds = totalSecond {
          let hour = seconds / 3600
          let mintues = (seconds % 3600) / 60
          let second = seconds % 60
          
          return  String(format: "%02d",hour) + ":" +
                  String(format: "%02d", mintues) + ":" +
                  String(format: "%02d", second)
      } else {
          return "88:88:88"
      }
  }
8月3日

转换十六进制颜色值:
Objective-C

#define HEXCOLOR(rgbValue) [UIColor colorWithRed:((float)((rgbValue & 0xFF0000) >> 16))/255.0 green:((float)((rgbValue & 0xFF00) >> 8))/255.0 blue:((float)(rgbValue & 0xFF))/255.0 alpha:1.0]

Swift:

//  十六进制颜色转换
func HEXCOLOR(rgbValue: Int) -> UIColor {
    return UIColor.init(red: CGFloat(Double(((rgbValue & 0xFF0000) >> 16)) / 255.0), green: CGFloat(Double(((rgbValue & 0xFF00) >> 8)) / 255.0), blue: CGFloat(Double((rgbValue & 0xFF)) / 255.0), alpha: 1.0)
}
8月8日
  1. 雷达动画核心代码,最适合用在地图中:

![效果图]](https://img.haomeiwen.com/i1910830/a1d6abdfde26943c.gif?imageMogr2/auto-orient/strip)

  // 调制颜色
  struct Contants {
      struct ColorPalette {
          static let green = UIColor(red:0.00, green:0.87, blue:0.71, alpha:1.0)
      }
  }
  /**
   核心动画
   
   - parameter beginTime: 启动时间间隔
   */
  func sonar(beginTime: CFTimeInterval) {
      let circlePath1 = UIBezierPath(arcCenter: self.view.center, radius: CGFloat(3), startAngle: CGFloat(0), endAngle: CGFloat(M_PI * 2), clockwise: true)
      
      let circlePath2 = UIBezierPath(arcCenter: self.view.center, radius: CGFloat(80), startAngle: CGFloat(0), endAngle: CGFloat(M_PI * 2), clockwise: true)
      
      let shapeLayer = CAShapeLayer()
      shapeLayer.strokeColor = Contants.ColorPalette.green.CGColor        //  边缘颜色
      shapeLayer.fillColor = Contants.ColorPalette.green.CGColor
      shapeLayer.path = circlePath1.CGPath
      self.view.layer.addSublayer(shapeLayer)
      
      let pathAnimation = CABasicAnimation(keyPath: "path")
      pathAnimation.fromValue = circlePath1.CGPath
      pathAnimation.toValue = circlePath2.CGPath
      
      let alphaAnimation = CABasicAnimation(keyPath: "opacity")
      alphaAnimation.fromValue = 0.8
      alphaAnimation.toValue = 0.0
      
      let animationGroup = CAAnimationGroup()
      animationGroup.beginTime = beginTime
      animationGroup.animations = [pathAnimation, alphaAnimation]
      animationGroup.duration = 2.76
      animationGroup.repeatCount = FLT_MAX
      animationGroup.delegate = self
      animationGroup.removedOnCompletion = false
      animationGroup.fillMode = kCAFillModeForwards
      
      shapeLayer.addAnimation(animationGroup, forKey: "sonar")
  }
  
  /**
   启动动画
   */
  func startAnimation() {
      sonar(CACurrentMediaTime())
      sonar(CACurrentMediaTime() + 0.92)
      sonar(CACurrentMediaTime() + 1.84)
  }
8月23日

ijkplayerDemo 编译方法

8月24日
  1. 隐藏 UITabBar 的灰色线条:
        let tabBar = UITabBar.appearance()
        tabBar.shadowImage = UIImage()
        tabBar.backgroundImage = UIImage()
8月29日
  1. Swift 格式化输出:

参考链接:SwiftTips-Log输出

/**
自定义Log输出

- parameter message: 输出信息
- parameter file:    输出方法所在文件名
- parameter method:  所在方法名
- parameter line:    所在行数
*/
public func printLog<T>(message: T,
                    file: String = #file,
                    method: String = #function,
                    line: Int = #line) {
   
   #if DEBUG
   print("👉👉\((file as NSString).lastPathComponent)[\(line)] \(method)👈👈: \(message)")
   #endif
}

在 Swift 中,编译器为我们准备了几个很有意义的编译符号,分别是:

符号 类型 描述
#file String 包含这个符号的文件的路径
#line Int 符号出现处的行数
#column Int 符号出现处的列数
#function String 包含这个符号的方法名字

这样还不足够,还要配置 DEBUG 这个宏,否则不能正确输出:

配置DEBUG宏定义
2017年3月7日

1.设置微信为白名单:
info.plist 添加代码:

<key>LSApplicationQueriesSchemes</key>
<array>
<string>weixin</string>
</array>
上一篇 下一篇

猜你喜欢

热点阅读