Images.xcassets

概述

功能

方便用户管理图像资源。

图片获取方式

  • Images.xcassets中的图片资源只能通过imageNamed:方法加载,通过NSBundle的pathForResource:ofType:无法获得图片路径。
  • 因此,Images.xcassets只适合存放系统常用的,占用内存小的图片资源。

AppIcon

例1


- finder中显示


- content.json

- iPhone6s plus上的显示


- iPhone6上的显示

此时修改图片集

拖入60pt 2x图片


总结

  • 每一组下面的像素数目指的的为1x的时候的图片的大小(iPhone4之前为1x)
  • 若拖入的图片不符合尺寸,编译将无法通过。应该先裁剪出对应大小的图片,再拖入界面中对应的位置
  • 上图中从左到右,图片尺寸分别是:120120,140140。
  • 可以看到,拖入的文件名在content.json中有显示
  • 如果2x存在60pt或者40 pt对应的文件时,在spotlight和App icon都将使用该图片scale后的对应大小
    ###例2
    AppIcon尺寸
  • finder中查看
  • iPhone6s上

  • iPhone6p上的App图标
  • 如果此时再来修改AppIcon图片集
    • 若此时添加40pt 2x对应的图片,再运行spotlight中显示的还是之前的app icon
    • 即使把xcode中60pt 2x的图片删除,在content.json中也看到对应的图片名字消失了。但是在iPhone6上看到的App icon还是下面这个样子


  • 拖入新的60pt 2x的图片


    ###总结
  • 如果只是删除2x或3x的全组图片。那么显示仍采用之前的图片
  • 拖入新的图片文件后,无需更改,手机即可显示新的图标
  • 如果spotlight的图片不是一开始就设置好的话,那么后期拖入不会改变spotlght上显示的icon

用户图片资源

新建文件夹和图片集

  • 通过New Folder建立新的文件

  • 通过New Image Set建立新的图片集

拖入裁减好的图片

  • 代码引用方式

    • name使用的是image set的名字
    • 双击iamge set即可修改图片集的名字
 self.header.image = [UIImage imageNamed:@"header"];
self.suit.image = [UIImage imageNamed:@"closing"];
  • 运行界面

修改显示的图片

无需修改代码,只需将图片拖入对应的Image Set即可

总结

  • 从本例中可看出使用xcassets管理图片资源的方便之处:可以更换图片而无序修改代码
  • 图片很好地存放在xcasset中,项目中不会看到大量的混乱的图片文件

补充:

若需要导入其他项目Image.assset中的图片,只需分别在finder中打开两个项目的Image.assset,复制粘贴所需图片对应的文件夹即可

Images.xcassets的更多相关文章

  1. Images.xcassets不能获取图片路径

    原文地址:http://www.jianshu.com/p/5358f587af38 Images.xcassets在app打包后,以Assets.car文件的形式出现在bundle中.其作用在于: ...

  2. Impossible to load an image in xcassets on bundle

    Impossible to load an image in xcassets on bundle up vote5down votefavorite 3 I need to include imag ...

  3. 想在Images.xcassets 只能用 imageNamed 加载里边的素材 其他方法 你就别费老劲了

    1.Images.xcassets中的素材 (1)只支持png格式的图片 (2) 图片只支持[UIImage imageNamed]的方式实例化,但是不能从Bundle中加载 (3)  在编译时,Im ...

  4. 实现iOS图片等资源文件的热更新化(一): 从Images.xcassets导出合适的图片

    本文会基于一个已有的脚本工具自动导出所有的图片;最终给出的是一个从 Images.xcassets 到基于文件夹的精简 合适 的图片资源集的完整过程.难点在于从完整图片集到精简图片集,肯定是基于一个定 ...

  5. 如何获得images.xcassets 中图片的路径?

    UIImage加载图片的方式以及Images.xcassets对于加载方法的影响 重点: Images.xcassets中的图片资源只能通过imageNamed:方法加载,通过NSBundle的pat ...

  6. Xcode中将图片放入Images.xcassets和直接拖入的区别

    将图片放入Images.xcassets 在mainBundle里面Xcode会生成一个Assets.car文件,将我们放在Images.xcassets的图片打包在里面.(程序会变大(?)) 无论是 ...

  7. 有关ios中images.xcassets的导入图片等命名问题

    最近遇到一个问题,就是在设置启动图片的时候,把启动图片命名设置为了xxx@2x.png, 然后应用死活没有显示启动图片,调试了很久,才发现是因为文件命名的原因. 1. 如果在图片的下方有2x或3x的标 ...

  8. Xamarin中 ios 修改Assets.xcassets 文件后 无法调试和编译

    根本问题是因为 vs项目里面 没有包含 如果提示找不到对应png 请检查 iOS 项目卸载后 编辑 并找到对应文件检查 <ImageAsset Include="Assets.xcas ...

  9. 设置Images.xcassets后启动仍旧黑屏的问题

    换了XCode6之后,发现以前写Icon-76.png这样很麻烦,就使用了Image.xcassets,公司所有测试机跑了一下,发现没什么问题.唯独有一台设置有问题,iphone5 ios6.0系统, ...

随机推荐

  1. 实现了IEnumerable接口的GetEnumerator 即可使用 Foreach遍历,返回一个IEnumerator对象

    #region 程序集 mscorlib.dll, v4.0.0.0 // C:\Program Files (x86)\Reference Assemblies\Microsoft\Framewor ...

  2. QQ--模拟发表带图说说

    发表说说之前,必须登录. 模拟QQ登录 >> http://www.cnblogs.com/deeround/p/4386629.html 发表带图说说,自然少不了上传图片,我这使用的PC ...

  3. Pydev Debugger not working with breakpoints

    I have a simple test module: print("fish")print("sticks")It runs pretty fast as ...

  4. 2016 长春东北赛---Coconuts(离散化+DFS)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=5925 Problem Description TanBig, a friend of Mr. Frog ...

  5. PHP内核探索之变量(3)- hash table

    在PHP中,除了zval, 另一个比较重要的数据结构非hash table莫属,例如我们最常见的数组,在底层便是hash table.除了数组,在线程安全(TSRM).GC.资源管理.Global变量 ...

  6. Guava学习笔记目录

    Guava 是一个 Google 的基于java1.6的类库集合的扩展项目,包括 collections, caching, primitives support, concurrency libra ...

  7. Java继承中成员方法的overload(重载/过载)

    如果Java基础类有一个方法名被"过载"使用多次,在衍生类里对那个方法名的重新定义就不会隐藏任何基础类的版本.所以无论方法在这一级还是在一个基础类中定义,过载都会生效. publi ...

  8. TreeSet集合深入了解--------攻击原理

    Set接口Set不允许包含相同的元素,如果试图把两个相同元素加入同一个集合中,add方法返回false.(无序,不可重复 )Set判断两个对象相同不是使用==运算符,而是根据equals方法.也就是说 ...

  9. 使用 HTML5 WebGL 实现逼真的云朵效果

    这里给大家展示一个使用 HTML5 WebGL 实现超逼真的云朵效果.WebGL 是一项在网页浏览器呈现3D画面的技术,有别于过去需要安装浏览器插件,通过 WebGL 的技术,只需要编写网页代码即可实 ...

  10. div水平居中

    1.先给它外层的div定位并left:position:absolute;left:50%; 2.获取当前元素div的宽度,并除以2 3.改变它的css:margin-left:-(获取当前元素div ...