图片的切片拉伸(iOS Slicing与Android中点9图)

一 前言

在项目开发中,在UI切图不全的情况下,我们可以通过放大缩小图片某个区域适配各种机型防止背景图片变形。iOS可以通过UIImage的方法resizableImageWithCapInsets切片设置图片的可拉伸区域,也可以通过slicing(基于OS7以上的 并且用Media.xcassets管理图片)可视化的制定图片的可扩展和不可变区域 。类似于Android中的点9图片。当然,你不怕麻烦可以在图层上画出来各种情况下的背景。

二.Androd中的点9图

点9图示一种可伸缩的位图,如果你某个View用了点9图做background,Android会根据点9图的设置来自动为你调整、适应内容。点9图是标准的PNG格式图像,被一圈1像素宽的边缘包围,并且保存的时候扩展名一定要是“.9.png”,还要保在“res/drawable/”目录。(最外围的一圈像素必须要么是纯黑色,要么是透明,一点点的半透明的像素都不可以有,比如说99%的黑色或者是1%的投影都不可以有

Paste_Image.png

三.iOS中的切片缩放

iOS的图片Slicing,同等于Android中的点9图片。iOS可以通过UIImage的方法resizableImageWithCapInsets切片设置图片的可拉伸区域,也可以通过slicing(基于OS7以上的 并且用Media.xcassets管理图片)可视化的制定图片的可扩展和不可变区域

代码实现:

   UIImage *image = [UIImage imageNamed:@"004"];
   CGFloat top = 10; 
   CGFloat left = 10; 
   CGFloat bottom = 10; 
   CGFloat right = 10; 
   /// 顶端、左端、底部、右端分别预留距离
   UIEdgeInsets insets = UIEdgeInsetsMake(top, left, bottom, right);
   //注意:拉伸之后一定要赋值回去 
  image = [image  resizableImageWithCapInsets:insets 
   resizingMode:UIImageResizingModeStretch]; 
   //UIImageResizingModeStretch:`拉伸`模式,通过`拉伸`Insets指定的矩形区域来填充图片 
   //UIImageResizingModeTile:`平铺`模式,通过`重复显示`Insets指定的矩形区域来填充图片

通过 Xcode Slicing: (xcode的slicing功能是UIImage的- resizableImageWithCapInsets:resizingMode:可视化操作)

打开项目中Images.xcassets文件,找到你想操作的图片,点击XCode右下方


Paste_Image.png

此时图片上会展示出 Start Slicing 按钮,点击按钮,根据需求选择水平、垂直、水平与垂直不通Slicing方式


Paste_Image.png

此时图片水平和垂直分别出现三条线,可以理解成,中间的两条线可以先不用管,默认让它分别贴着下边线和右边线,另外的四条线交叉中间那个矩形区域就是用来拉伸或者平铺的,只有四个角上的内容不会变(实际意义上:以垂直方向为例,中间到左面那条线是图片填充像素,中间条到右面是隐藏填充区域。矩形左边那块是用来重复的,右边那块是用来覆盖的,但有的时候不起作用,原因不详)

Paste_Image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,711评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,079评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,194评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,089评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,197评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,306评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,338评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,119评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,541评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,846评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,014评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,694评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,322评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,026评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,257评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,863评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,895评论 2 351

推荐阅读更多精彩内容

  • 返回一张受保护且被拉伸的图片 应用场景:聊天窗口的气泡 方法一(弃用): iOS 5.0以前使用(弃用)这个方法会...
    林安530阅读 15,679评论 1 36
  • 在Google一些东西的时候,发现了这篇博文,觉得非常之好,就转载过来,非常感谢博主的分享精神。博文原地址:htt...
    流星大石头阅读 5,034评论 2 25
  • 转载:http://www.jianshu.com/p/18c306333080 1.UIView与CALayer...
    F麦子阅读 533评论 0 1
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,914评论 25 707
  • 七月的风懒懒的,连云都变得热热的..... 夏天的风正暖暖吹过 吹过头发,穿过耳朵 ——《夏天的风》 风吹进了三路...
    依语鱼阅读 504评论 0 0