iOS->那些容易被人所忽略的小技巧总结分享(二)

前言 : 在开发中我们经常会遇到一些小问题或者是发现一些小技巧,但我们往往都是觉得自己这次知道了就好了,并没记录起来,做了那么久开发难免会遗忘基础,那么我就把一些常用的常遇到的小技巧总结起来

总结(篇章二) ->之前那第一篇得到了大家的支持,我会继续发布完整

  • 设置图片的内容模式 (新手会比较纠结)
// 1. 设置图片的内容模式 (设置为不会变形的填充模式)
imageView.contentMode = UIViewContentModeScaleAspectFill; 
// 2. 裁剪超出的内容
imageView.clipsToBounds = YES;
  • 详解内容模式
// 重绘Redraw ,这个牵扯到核心绘图drawRact,后面会详解这方面的技巧
UIViewContentModeRedraw,  
// 带Scale单词: 表明图片有可能会 变形(拉伸或者压缩)
UIViewContentModeScaleToFill,
// 带有Aspect单词: 会等比例缩放图片(一定不会变形)
// 补充:等比例缩放与变形是两回事,别混淆
// fit:自适应(图片等比例显示完整,如果内容区过大会留白)
UIViewContentModeScaleAspectFit,
// fill:填充(填充满图片内容区,但图片过大时会导致图片显示不完全)
UIViewContentModeScaleAspectFill, 
// 不带Scale单词: 表明图片不可能被拉伸或者压缩(变形)
UIViewContentModeCenter, // 居中显示
UIViewContentModeTop, // 显示顶部
UIViewContentModeBottom, //显示底部
UIViewContentModeLeft, //左
UIViewContentModeRight, //右
UIViewContentModeTopLeft, //上+左
UIViewContentModeTopRight, //上+右
UIViewContentModeBottomLeft, //底+左
UIViewContentModeBottomRight, //底+右
  • 图片的'两种加载方式'所引发的'两种资源存放方式'
->图片的两种加载方式:
加载方式一:  imageNamed: 
//此方式加载图片,就算没有强指针指向,也不会从内存中被干掉 (默认带有缓存)
//使用场景:图片经常会被使用或是少量的图片
// 例子:
imageView.image = [UIImage imageNamed:@"photo.jpg"];
//
加载方式二:  imageWithContentsOfFile:
//此方式加载图片,如果没有强指针指向,就会从内存中被干掉 (默认不带有缓存)
使用场景:图片不经常被使用或是大批量的图片
// 例子 (自由路径):
imageView.image = [UIImage imageWithContentsOfFile:@"/Users/zhq/Desktop/UI小技巧/总结/资源/图片/photo.jpg"];
// 例子 (资源包的路径)
NSString *path = [[NSBundle mainBundle] pathForResource:@"photo.jpg" ofType:nil];
imageView.image = [UIImage imageWithContentsOfFile:path];
//
->资源的两种存放方式
 存放方式一. Assets.xcassets:
 1.在资源包中对应的是Assets.car
 2.放到Assets.xcassets中的图片是无法获取到路径的
 3.只能通过imageNamed:这种方式来加载图片
 4.不能通过imageWithContentsOfFile:这种方式来加载图片
 5.放到Assets.xcassets中的图片默认就带有缓存
 存放方式二. 放到项目目录中:
 1.图片资源会被打包到MainBundle中 (注意回看 例子(资源包的路径))
 2.能够获取到图片的路径
 3.即能通过imageNamed:这种方式来加载图片
 4.也能通过imageWithContentsOfFile:这种方式来加载图片
  • 关于毛玻璃,看过很多文章都在神话这技术,或者不知道这个东西的人会觉得这个可能很难,实质上这个东西 简 单 的 很 !!!!!!!!!!!!!
//1. 创建毛玻璃(实质上是工具栏)
UIToolbar *toolBar = [[UIToolbar alloc] init];
//2. 设置尺寸
toolBar.frame = imageView.bounds;
//3. 设置工具栏的样式
toolBar.barStyle = UIBarStyleBlack;
//4. 设置透明度
toolBar.alpha = 0.98;  
//5. 加入到需要被模糊化的视图中
[imageView addSubview:toolBar];
  • 关于九宫格的算法,有些初学者会觉得比较难,还有些人九宫格会了然后看见4个格子,7个格子,13个格子就懵逼了,不管多少格子,实质算法都是一样的
 // 计算出 格子的x值 和 格子的y值 (万能公式)
    CGFloat x = (列距 + 格子宽度) * (格子角标 % 总列数);
    CGFloat y = (行距 + 格子高度) * (格子角标 / 总列数);
补充: 
1.列距:指在"一行"当中,每个格子间的'水平'距离
2.行距:指在"行与行"之间,行与行之间的'竖直'距离
3.格子角标:第一个格子为0,计算完后依次递增
4.总列数: 取某行当中最大的列数
5.格子宽度和高度:指的是每个格子'自身'的宽高
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,378评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,356评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,702评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,259评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,263评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,036评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,349评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,979评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,469评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,938评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,059评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,703评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,257评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,262评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,485评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,501评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,792评论 2 345

推荐阅读更多精彩内容