就算在牛逼的大神也不一定有好的記性窥岩,在開發(fā)中有時(shí)候一些小點(diǎn)就是想不起來黔夭。這里總結(jié)下最近遇到的吞获,不定期更新--
1柳爽、 關(guān)閉隱式動(dòng)畫
開發(fā)中有時(shí)候會(huì)遇到莫名其妙不希望出現(xiàn)的動(dòng)畫进鸠,肯定是系統(tǒng)的隱式動(dòng)畫再起作用稠曼,layer層屬性默認(rèn)是帶動(dòng)畫的 可以用下面的方式禁掉
CATransaction.begin()
CATransaction.setDisableActions(true) // 關(guān)閉動(dòng)畫
//你的代碼
CATransaction.commit()
2、文件存取
在開發(fā)中有時(shí)候要本地緩存一些文件文件只能放在document文件夾下才能存取
下面是獲取文件夾目錄方式
let paths = NSSearchPathForDirectoriesInDomains(NSSearchPathDirectory.DocumentDirectory, NSSearchPathDomainMask.UserDomainMask, true)
let documentDirectory = paths[0]
后面加自己設(shè)定的目錄就行了
下面放下我寫的文件讀取的方法 傳入key folder等 自己摸索吧客年。
//MARK: -從文件獲取用戶信息
static func getUserFromDisk(key:String,folder:String)->AnyObject?{
//反歸檔 獲取
let fileManager = NSFileManager.defaultManager()
if fileManager.fileExistsAtPath(folder){
let mdata = NSMutableData(contentsOfFile:folder )
let unArchiver = NSKeyedUnarchiver(forReadingWithData: mdata!)
let u = unArchiver.decodeObjectForKey(key)
return u
}
return nil
}
static func saveModelToFile(key:String,value:AnyObject?,folder:String){
let data = NSMutableData()
var keyArchiver:NSKeyedArchiver!
keyArchiver = NSKeyedArchiver(forWritingWithMutableData: data)
keyArchiver.encodeObject(value, forKey: key)
keyArchiver.finishEncoding() //歸檔完畢
do {
try data.writeToFile(folder, options: NSDataWritingOptions.DataWritingAtomic)
}catch let err{
print("err:\(err)")
}
}
3霞幅、http圖片或者網(wǎng)絡(luò)不能訪問
http開頭蘋果認(rèn)為不是安全的連接,要手動(dòng)配置下量瓜,在plist里加上如下代碼
<key>NSAppTransportSecurity</key>
<dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
</dict>
4司恳、判斷兩個(gè)矩形是否相交
CGRectIntersection(<#T##r1: CGRect##CGRect#>, <#T##r2: CGRect##CGRect#>)
5、解決添加tap手勢后點(diǎn)擊cell無響應(yīng)
實(shí)現(xiàn)UIGestureRecognizerDelegate協(xié)議下面的方法
func gestureRecognizer(gestureRecognizer: UIGestureRecognizer, shouldReceiveTouch touch: UITouch) -> Bool {
if NSStringFromClass(touch.view!.classForCoder) == "UITableViewCellContentView"{
return false
}
return true
}
5绍傲、tableView自動(dòng)布局高度自適應(yīng)
至于怎么約束扔傅,不再這里討論
tableView.estimatedRowHeight = 50 //預(yù)估高度
tableView.rowHeight = UITableViewAutomaticDimension
6、讀取plist文件
let plistPath = NSBundle.mainBundle().pathForResource("SampleData", ofType: "plist")
if let plistPath=plistPath{
let arr = NSArray(contentsOfFile: plistPath)
print(arr)
}
7烫饼、tableView不顯示多余行猎塞,不顯示分割線,從xib中注冊
tableView.separatorStyle = UITableViewCellSeparatorStyle.None
tableView.tableFooterView = UIView(frame: CGRectZero)
tableView.registerNib(UINib(nibName: "homePageCell", bundle: NSBundle.mainBundle()), forCellReuseIdentifier: "cell") //從nib 注冊cell
8杠纵、自定義導(dǎo)航欄的一些屬性
//自定義一些導(dǎo)航欄的顏色
UINavigationBar.appearance().barTintColor = UIColor(red: 231.0/255.0, green: 95.0/255.0, blue:
53.0/255.0, alpha: 0.3)
UINavigationBar.appearance().tintColor = UIColor.whiteColor()
if let barFont = UIFont(name: "AvenirNextCondensed-DemiBold",
size: 22.0) {
UINavigationBar.appearance().titleTextAttributes =
[NSForegroundColorAttributeName:UIColor.whiteColor(),
NSFontAttributeName:barFont]
}
self.navigationItem.backBarButtonItem = UIBarButtonItem(title: "", style: .Plain, target: nil, action: nil) //返回按鈕位空
9 荠耽、自定義tabbar的一些屬性
UIBarButtonItem.appearance().tintColor = UIColor(red: 235.0/255.0, green: 73.0/255.0, blue:
27.0/255.0, alpha: 1.0)
UIToolbar.appearance().barTintColor = UIColor(red: 237.0/255.0, green: 240.0/255.0, blue:
243.0/255.0, alpha: 0.5)
10、UIImagePickerController 選擇圖片的簡單實(shí)用(單選)
//如果相冊可用
if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.PhotoLibrary){
let imagePicker = UIImagePickerController()
imagePicker.allowsEditing = false
imagePicker.sourceType = UIImagePickerControllerSourceType.PhotoLibrary
self.presentViewController(imagePicker, animated: true, completion: nil)
}
11比藻、擴(kuò)展UIImage的兩個(gè)方法
extension UIImage{
//圖像比例縮放
func scaleImage(img:UIImage,scaleSize:CGFloat)->UIImage{
UIGraphicsBeginImageContext(CGSizeMake(img.size.width * scaleSize, img.size.height * scaleSize))
img.drawInRect(CGRectMake(0, 0, img.size.width * scaleSize, img.size.height * scaleSize))
let scaledImage = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
return scaledImage
}
//自定長寬
func reSizeImage( toSize:CGSize)->UIImage{
UIGraphicsBeginImageContext(CGSizeMake(toSize.width, toSize.height));
self.drawInRect(CGRectMake(0, 0, toSize.width, toSize.height))
let reSizeImage = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
return reSizeImage;
}
}
12铝量、空數(shù)據(jù)顯示方案
import UIKit
extension UITableView{
//MARK: -空table的解決方案
func tableViewMsgWhenEmpty(message:String,rowCount:Int){
if rowCount == 0{
//沒有數(shù)據(jù)
let messageLabel = UILabel()
// Display a message when the table is empty
messageLabel.text = message;
messageLabel.textColor = MAIN_COLOR
messageLabel.numberOfLines = 0
messageLabel.textAlignment = NSTextAlignment.Center
messageLabel.font = UIFont.systemFontOfSize(17)
messageLabel.sizeToFit()
self.backgroundView = messageLabel
messageLabel.frame = CGRectMake(0, 0, self.frame.width, self.frame.height)
messageLabel.sizeToFit()
self.separatorStyle = UITableViewCellSeparatorStyle.None
}else{
//有數(shù)據(jù)
self.backgroundView = nil
self.separatorStyle = UITableViewCellSeparatorStyle.SingleLine
}
}
}
13倘屹、上傳照片的時(shí)候要先壓縮下,不然一個(gè)圖片幾M 上傳到服務(wù)器太浪費(fèi)資源
let data = UIImageJPEGRepresentation(img,0.5)
第一個(gè)參數(shù)是UIImage對象 第二個(gè)是壓縮比率 慢叨,應(yīng)該不會(huì)失真
14纽匙、對象的序列化與反序列化
class Tag: NSObject,NSCoding {
var id:NSNumber?
var name:String?
override init() {
}
//MARK: -序列化
func encodeWithCoder(aCoder: NSCoder) {
aCoder.encodeObject(self.name, forKey: "name")
aCoder.encodeObject(self.id, forKey: "id")
}
//MARK: -反序列化
required init?(coder aDecoder: NSCoder) {
self.id = aDecoder.decodeObjectForKey("id") as? NSNumber
self.name = aDecoder.decodeObjectForKey("name") as? String
}
}
15、跳轉(zhuǎn)明細(xì)頁的時(shí)候隱藏tabbar
let followsVC = FollowsViewController()
followsVC.hidesBottomBarWhenPushed = true
self.navigationController?.pushViewController(followsVC, animated: true)
16拍谐、iOS8以上UITableCell左邊不留空哄辣,一點(diǎn)空都沒有哦
cell.preservesSuperviewLayoutMargins = false
cell.layoutMargins = UIEdgeInsetsZero
17、Segue相關(guān)的幾個(gè)方法
//用來判斷是否需要跳轉(zhuǎn)
override func shouldPerformSegueWithIdentifier(identifier: String, sender: AnyObject?) -> Bool {
if xxxxx == nil{
return false
}
return true
}
//可以用代碼 直接控制跳轉(zhuǎn)
override func performSegueWithIdentifier(identifier: String, sender: AnyObject?) {
}
//是點(diǎn)擊界面上的按鈕 根據(jù)你綁定的跳轉(zhuǎn)界面進(jìn)行跳轉(zhuǎn)
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
}
18赠尾、http 請求需要在plist添加如下代碼塊
<key>NSAppTransportSecurity</key>
<dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
</dict>
19力穗、DM5加密
extension String{
//MARK: -字符串替換
func myreplace(oldStr:String,newStr:String)->String{
return self.stringByReplacingOccurrencesOfString(oldStr, withString: newStr, options: NSStringCompareOptions.NumericSearch, range: nil)
}
//MARK: -MD5算法
func md5() ->String!{
let str = self.cStringUsingEncoding(NSUTF8StringEncoding)
let strLen = CUnsignedInt(self.lengthOfBytesUsingEncoding(NSUTF8StringEncoding))
let digestLen = Int(CC_MD5_DIGEST_LENGTH)
let result = UnsafeMutablePointer<CUnsignedChar>.alloc(digestLen)
CC_MD5(str!, strLen, result)
let hash = NSMutableString()
for i in 0 ..< digestLen {
hash.appendFormat("%02x", result[i])
}
result.destroy()
return String(format: hash as String)
}
}