问题
今天在设置NavgationItem上的Bar Button Item时出了点问题。
首先,先添加Bar Button Item。
data:image/s3,"s3://crabby-images/441b6/441b6e5cc79a21bd381d8bc7c3e0af1cbfbe54fa" alt="Bar Button Item"
Bar Button Item
然后设置图片为自己的图片,logo.png。
data:image/s3,"s3://crabby-images/de55e/de55e360255a4ea157303c56977508756ea522ed" alt="logo"
logo
data:image/s3,"s3://crabby-images/edff9/edff928cc3ac33774e5e9fcc9b007c54bc8265f6" alt="Bar Item"
Bar Item
奇怪的是这时候StoryBoard上面,显示为一块蓝色。
data:image/s3,"s3://crabby-images/13f86/13f863fe27d75a9bd4712eea9d73ceba965a1ae8" alt="StoryBoard"
StoryBoard
而且运行的时候,同样出现了这种情况。
data:image/s3,"s3://crabby-images/73995/73995e8485a5eaf6c144a4ef903edab9e62ce422" alt="运行后"
运行后
原因具体见这篇文章:
【GeekBand】UITabBarItem与UIImageRenderingMode
这是以前在Tabbar上面设置图标的时候也遇到了问题,并已经解决。
解决(一)
所以我们只要在对应的代码里面这样写
NSArray<UIBarButtonItem*> *array= self.navigationItem.rightBarButtonItems;
UIBarButtonItem *item= array[0];
item.image = [[UIImage imageNamed:@"logo.png"]imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
再继续运行
data:image/s3,"s3://crabby-images/32e1f/32e1fc96d227ee5df4b425cf8fcf1c23c2d13728" alt="成功"
成功
成功实现。
解决(二)
先把一开始设定BarButtonItem的代码删掉。
其实我们这里写代码只是设置了image的RenderingMode模式,可不可以不用代码,在StoryBoard上面直接修改呢?
data:image/s3,"s3://crabby-images/90896/90896cb22bdf94b75e3be123d91cdb747b5f5546" alt="BarButtonItem"
BarButtonItem
发现BarButtonItem中并没有这个选项。
如果不修改StoryBoard,修改图片可以么?
点击放在Assert.xcassets中的图片。
data:image/s3,"s3://crabby-images/7ec2c/7ec2c96539dbdc8f88b95188d09772ea4cf25044" alt="Assert.xcassets"
Assert.xcassets
然后查看选项
data:image/s3,"s3://crabby-images/67ffc/67ffc00666e12ac24c187bc400794bc4922ff952" alt="Render As"
Render As
看到Render As这个选项了吗?
这个选项很关键,把它设置为Original Image。
再次运行。
data:image/s3,"s3://crabby-images/32e1f/32e1fc96d227ee5df4b425cf8fcf1c23c2d13728" alt="成功"
成功
成功实现!