这篇文章实时更新iOS开发过程中小小得Tips,没有高深的算法和程序架构,设计。就是一个备忘录![最近发现倒序比较好写。。。。。]
欢迎加入我个人维护QQ群:379069176
PS:定期分享干货
2017年2月23日更新
【Xcode 工程文件打开不出来, cannot be opened because the project file cannot be parsed. 】遇到这种情况的人不在少数,今天写出解决方案
原因:.xcodeproj工程文件冲突了,然后还是会强制更新,内部文件出现了冲突,所以解析不了文件
解决方案:
1.对.xcodeproj 文件右键,显示包内容
2.双击打开 project.pbxproj 文件
3.找到以上类似的冲突信息(可以用commad + f 搜索)
4.删除 <<<<<<<,======,>>>>>>这些行
5.保存,退出
6.重新打开.xcodeproj文件即可
2017年1月17日更新
swift提供的四舍五入方法。有一段时间一直用自己的算法。。。。😁
let decimal = 3.14
print(decimal.dynamicType) // Double
print(floor(decimal)) // 3.0 (如果参数是小数,则求最大的整数但不大于本身.)
print(ceil(decimal)) // 4.0 (如果参数是小数,则求最小的整数但不小于本身.)
print(round(decimal)) // 3.0 (如果参数是小数,则求本身的四舍五入)
保留小数点后几位的方式:
let decimal = decimal * 10
print(floor(decimal) / 10) // 3.1
print(ceil(decimal) / 10) // 3.2
print(round(decimal) / 10) // 3.1
2016年11月14日更新
设置leftBarButtonItem之后,自动会隐藏backButton
2016年9月5日更新
在给cell添加手势的时候获取indexPath:
tableView.indexPathForRowAtPoint(sender.locationInView(tableView))
2016年7月01日更新
今天在维护现有项目中,还是遇到了tableview的问题,果然充分掌握好tableview确实是重要之重的事情。这个问题可能很多人都知道,我这里只是给自己做一个备份。
问题是这样的,自己做了一个cell拖拽之后弹出actionSheet的功能。在测试的时候,拖拽之后点击其他cell进入其他页面后,actionSheet弹出,显然这不是我们自己想要的效果。
有2点,首先,拖拽之后点击其他cell进入其他页面后,不应该弹出actionSheet才对,或者说,一开始在cell拖拽的时候就不应该让用户能够点击其他cell。按照常理来说的话,用户在拖拽cell的时候肯定不会想点击进入别的cell的心理。所以我们的解决方法就是使得用户在拖拽cell的时候,不允许用户点击其他cell。那么具体实现方法是什么呢?
新人【比如我】可能首先想到的是,获取到当前cell,其他cell修改成不可选择。因为我们对API不熟悉所以会绕很多弯路。其实很简单就是将exclusiveTouch这个变量设置成为true即可【button经常使用】,这个变量就是说不可以复数选择view【继承自view】。这个技能今天get了!开心!
2016年5月31日更新
前天踩了一个大大大大大的坑。。。不知道小伙伴们有没有人踩到过,现在分享一下,虽然不是什么技术性的Tips但是遇到的人我觉得应该不少。因为大家一般不会去考虑这个地方。
首先介绍一下这个坑,项目需求要开发APP的TodayExtension组件,那感情好啊!正好哥们儿正好个人项目想导入这个东西,来吧开始!有激情肯定效率高哇,分分钟数据,UI全都搭建好了,ok执行!漂亮!成功,心里那个欢喜啊!好了,接下来的工作就是测试找错了【个人习惯做出一个功能就各种测试找BUG】。来了,当我在todayextension中添加很多扩展之后,上下滚动出界面再次滚动返回时,发现自己做的todayextension无法点击了。切换界面后又可以点击操作了。就是滚动之后不行。。。。。1不报错2不提示。打断点不触发。看内存很平稳。我去!谁给哥们儿开玩笑呢!我是找啊找。。。。。。真心一点办法都没了。最后使用出程序员和医生唯一的杀手锏【喝点热水】【重启一下试试】。
解决方法:
在DeBug的时候,很多情况下Xcode是无法彻底清除缓存的,换句话说,你修改完代码后,重新运行有可能代码正确而真机或者模拟器仍然停留在错误模式下,这个时候你就得卸载App或者重装自己的extension再次运行。这个Tips虽然不是什么技术性文章,我感觉大家容易忽视这点,我自己就忽视了这一点。所以写出来,希望能够给读者提供一些帮助吧。
PS: 另外,在editshemes中不可以设置automatically这个属性。
2016年5月18日更新
在制作app的时候,默认开发环境为英语,修改的地方如图:
在targets中选择自己的项目->Info->添加Localization native development region选项->设置成中文即可
2016年4月28日更新
很久没有更新了,最近遇到的坑比较少,全力在开发新的程序。今天确实遇到了一个坑,也许有很多人会了解过,这里做一个备份。情况如下:
首先present一个viewController然后有个关闭按钮,设置按钮的tintColor为白色,点击关闭按钮,此vc的view会加载另外的view,也就是说,点击的时候当前vc中view会发生改变。这里再设一个按钮,弹出actionSheet的提示【tintcolor使用系统默认】
好了,准备工作完成。【1个vc2个按钮,第一个按钮点击之后关闭当前的view加载另外一个view进入当前vc,第二个按钮点击之后弹出actionSheet】.ok!下面来看我的坑吧。
点击actionSheet按钮,弹出actionSheet,然后点击取消,将actionSheet这个东西dismiss掉,再点击关闭按钮。现在程序应该是这样走的。
弹出actionSheet-》点击取消-》actionSheet被取消-》点击关闭按钮-》当前的view1被删除,切换到view2.
好了,这个时候有2个变化了。按钮的tintColor会改变成系统默认的颜色【蓝色】并不是我们最开始设置的白色。这个地方不是一个错误,让自己找了大半天没找到。最后得到解决,方法如下:
closeButton.tintAdjustmentMode = .Normal
对,就这么简单,在自己设置tintColor的地方设置mode为Normal。
2016年3月23日更新
这3段代码是封装了给图片加水印,UIImage修改TintColor的功能,在U修改UIImage中TintColor是在做项目的时候遇到的坑。。一直使用UIImageView和UIButton所以一直忽略了UIImage是否可以直接修改TintColor,今天做项目的时候,果然卡在这里了,所以做个备份。
static func capture(size: CGSize, opaque: Bool = false, scale: CGFloat = 1, @noescape handler: (CGContext) -> ()) -> UIImage {
UIGraphicsBeginImageContextWithOptions(size, opaque, scale)
handler(UIGraphicsGetCurrentContext()!)
let image = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
return image
}
static func makeWaterMarkImage(originalImage originalImage: UIImage, markImage: UIImage) -> UIImage {
let img = Image.setImageTintColor(markImage, tintColor: UIColor.whiteColor())
let markImageW = img.size.width
let markImageH = img.size.height
let markImageX = originalImage.size.width - markImageW
let markImageY = originalImage.size.height - markImageH
let markImageRect = CGRect(x: markImageX, y: markImageY, width: markImageW, height: markImageH)
let resizedImageRect = CGRect(x: 0, y: 0, width: originalImage.size.width, height: originalImage.size.height)
let resultImage = Image.capture(resizedImageRect.size) { context in
originalImage.drawInRect(resizedImageRect)
img.drawInRect(markImageRect)
}
return resultImage
}
static func setImageTintColor(image: UIImage, tintColor: UIColor) -> UIImage {
let bounds = CGRect(x: 0, y: 0, width: image.size.width, height: image.size.height)
let resultImage = Image.capture(image.size) { context in
tintColor.setFill()
UIRectFill(bounds)
image.drawInRect(bounds, blendMode: .DestinationIn, alpha: 1.0)
}
return resultImage
}
2016年3月16日更新
let fileURL = imageURLs[indexPath.row]
if fileURL.fileURL {
fileURLs.append(fileURL)
continue
}
最近使用Alamofire的时候遇到一个问题,当获取页面上的URL进行图片下载的时候,如果图片本身存在于device中,也就是说获取的URL是本地fileURL,使用Alamofire下载就会崩溃,这个时候在使用Alamofire下载的时候如果存在fileURL时,将其摘除,上面的代码是项目中的,意思差不多,做个备案
- URL 发送请求时,报的错:
“App Transport Security has blocked a cleartext HTTP (http://) resource load since it is insecure. Temporary exceptions can be configured via your app’s Info.plist file”
上面的错误是,新的特性要求App内部访问网络请求的时候,要采用HTTPS协议,在请求的地址如果都是HTTP协议的话则会报错
解决方法:
在Info.plist中添加NSAppTransportSecurity 并设置类型 Dictionary ;
在 NSAppTransportSecurity 下添加 NSAllowsArbitraryLoads 并设置类型Boolean ,值设为 YES;
保存即可解决上面的问题。
2016年1月16日更新
2.添加替换系统print()方法,并在release模式下不打印:
进入:
Build Settings --->Swift Complier - Custom Flags
--->Other Swift Flags ---> Debug 添加"-D"和"DEBUG"
如图:
代码:
func LOG<T>(value: T, function: String = __FUNCTION__, file: String = __FILE__, line: Int = __LINE__) {
#if DEBUG
print("<\(file.lastPathComponent):\(line) \(function)> \(value)")
#endif
}
打印结果:
这种方式的打印个人感觉已经很好了!呵呵,有VC信息并且定位到输出位置。
2016年1月30日更新
最近群里有挺多新手问:
在swift中拼接的字符串转NSURL为什么会是nil
例如:
let URLString ="http://which.photos/dcmailer/push_status.php?device_id=<\(v.deviceId)>"
let URL = NSURL(string:URLString)!
然后上面返回的结果会是nil。原因很简单:转义方面的问题。所以我们要针对拼接的字符串进行一次encode
修改代码如下:
let URLString ="http://which.photos/dcmailer/push_status.php?device_id=<\(v.deviceId)>"
let encodeURL = URLString.stringByAddingPercentEncodingWithAllowedCharacters(NSCharacterSet.alphanumericCharacterSet())!
let URL = NSURL(string:encodeURL)!
这样就ok了!
2016年2月4日更新
swift中delegate的可选协议的默认实现
有一种情况,我们定义协议方法的时候想定义一些可选协议,当然方法有很多,我主要介绍的一种我自己经常用的直接上代码吧。
//代理方法
protocol DecoDesignViewControllerDelegate: class {
func decoDesignViewController(vc: DecoDesignViewController, didChangeTextAlign align: TextAlign)
func decoDesignViewController(vc: DecoDesignViewController, didChangeTextSize size: TextSize)
func decoDesignViewController(vc: DecoDesignViewController, didChangeTextColor color: DesignTextColor)
func decoDesignViewController(vc: DecoDesignViewController, didChangeTextAnimation textAnimation: TextAnimation)
func decoDesignViewController(vc: DecoDesignViewController, didChangeBackgroundColor backgroundColor: DesignBackGroundColor)
}
声明之后再在下面对这个协议进行扩展:
extension DecoDesignViewControllerDelegate {
func decoDesignViewController(vc: DecoDesignViewController, didChangeBackgroundColor backgroundColor: DesignBackGroundColor) {
}
}
把想要定义成可选的协议方法重新写一遍,不做任何实现,这样一来这个方法就会被视为可选的协议方法了。
2016年3月10日更新
view.autoresizingMask = [.FlexibleWidth, .FlexibleHeight]
2016年3月16日更新
override func shouldAutorotate() -> Bool {
return true
}
override func supportedInterfaceOrientations() -> UIInterfaceOrientationMask {
return .Portrait
}
让当前vc不可以横屏