6月24日
- 改变状态栏文字颜色,即时间、电池等的颜色:
首先, 在 plist 文件中添加 View controller-based status bar appearance ,并将其设置为 NO 。
然后, 在需要修改的页面的 `super.viewDidLoad()` 下面添加 UIApplication.sharedApplication().statusBarStyle = .LightContent 即可。
⚠️ 注意,这个操作会改变前后页的文字颜色。如果不同的页面不同展示,那么就改变 `style` 的值。
6月27日
- 当我们使用定位服务的时候,发现
CLLocationManagerDelegate
方法不执行,是因为我们没有授权定位。解决办法(注意,这两个字段在plist文件中中是找不到的,需要手动输入):
首先在 info.plist里加入对应的缺省字段 ,值设置为YES(前台定位写上边字段,前后台定位写下边字段)
NSLocationWhenInUseDescription // 使用时获取定位
NSLocationWhenInUseUsageDescription // 允许在前台获取GPS的描述
NSLocationAlwaysUsageDescription // 允许在前、后台获取GPS的描述
说明一下上面三个字段使用时的区别:NSLocationWhenInUseDescription
是最常用的一个设置,此时将字段 NSLocationAlwaysUsageDescription
设置为 String
类型,并加入描述文字,首次使用APP时,在使用定位的弹框提示中,下面小字显示自己的描述文字。NSLocationWhenInUseUsageDescription
字段设置为 Bool
值时,使用程序期间将程序后台运行,会再手机最上方提示自己的APP正在使用定位服务。NSLocationAlwaysUsageDescription
表示APP使用使用定位服务。这个在上传到AppStore审核时,必须要说明程序在哪里使用了实时定位服务,并且要说明实时定位会损耗电池寿命。
7月6日
- 获取本地视频的指定时间截图
首先,获取安装路径下 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日
- 获取设备外网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日
- 计算指定路径下文件的大小。
计算沙盒内部文件大小时用到这个方法:
// 文件大小,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日
- 将标准时间转换为时间串。
即 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
}
- 将总秒数转换为播放时间。
即 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日
- 雷达动画核心代码,最适合用在地图中:
// 调制颜色
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日
8月24日
- 隐藏
UITabBar
的灰色线条:
let tabBar = UITabBar.appearance()
tabBar.shadowImage = UIImage()
tabBar.backgroundImage = UIImage()
8月29日
- 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 这个宏,否则不能正确输出:
2017年3月7日
1.设置微信为白名单:
info.plist
添加代码:
<key>LSApplicationQueriesSchemes</key>
<array>
<string>weixin</string>
</array>