Skip to main content

Vector graphics in iOS

In past, designers had to create multiple versions of the same asset (1x, 2x, 3x) to satisfy multiple screen sizes. Using vector assets can save you time because you only have to generate the asset once. You just need an.xcassets file in your project for storing your images. In there, you can declare image sets to be “Vectors”.

A vector file contains a lot of metadata of an asset that tells the system how to render it's contents, independent of the screen's resolution. This also means that whenever we get larger screen resolutions, Xcode will be able to scale up your images from your already existing vector PDF for you, giving you automatic support for future devices for free.

Steps:-
  • Select “New Image Set” in your XCAsset.
  • Select the Attributes Inspector in Utilities panel.
  • Under the types drop-down menu, select "Vector"
  • Drag and drop your vector PDF
  • Use the Xcode image catalog image set as you would with any other image. For instance, calling --imageNamed: in code, and passing in the NSString literal name of the image set.
  • When you build your project, Xcode will automatically create @1x, @2x and @3x PNG files from the PDF that you've used in the Xcode asset catalog.
  • When you run the application, iOS will automatically pick the appropraite @1x, @2x or #3x image that Xcode generated based on the device requirements




Advantages:
  1. Vector drawables scales without losing image quality.
  2. We need only one asset file(.pdf in 1x size) for multiple vector images.
  3. Vector drawables can reduce the size of our app.
  4. Help us to easily support different iOS devices.

But there’s another advantage: When it comes to icons a typical use case is to embed the same icon in multiple scenarios. We can colorize icon strokes in Xcode as well, so there’s no need to store multiple color variants of your icons in yourImages.xcassets. You just need to set “Render as” to “Template image”.


typedef NS_ENUM(NSInteger, UIImageRenderingMode) {
    UIImageRenderingModeAutomatic,          // Use the default rendering mode for the context where the image is used
    UIImageRenderingModeAlwaysOriginal,     // Always draw the original image, without treating it as a template
    UIImageRenderingModeAlwaysTemplate,     // Always draw the image as a template image, ignoring its color information
} NS_ENUM_AVAILABLE_IOS(7_0);

  • UIImageRenderingModeAlwaysOriginal - Just like the option sounds, this mode tells the system to render your image exactly as it looks in your image's file.
  • UIImageRenderingModeAlwaysTemplate - This mode is our funnest mode. It scans your image, and creates a stencil/template from all pixels in your image that aren't transparent. It also ignores all color information in your image and uses the tintColor property on your UIView subclasses to fill these template pixels with the color of your choice.
  • UIImageRenderingModeAutomatic - This mode allows the system to decide how to render your image based on the image's environment. If your image is placed within places like UITabBars, UINavigationBars, UIToolbars, andUISegmentedControls, then your image will be rendered as AlwaysTemplate. Everywhere else will use theAlwaysOriginal rendering mode.

Then, your freshly added vector images are colorized in the tint color set in their properties in Interface Builder. If you can’t use Interface Builder and want to set the properties programmatically (in Swift):

myImageView.image = myImageView.image!.imageWithRenderingMode(UIImageRenderingMode.AlwaysTemplate)
myImageView.tintColor = UIColor.whiteColor()




Comments

  1. Really special blog post, Thanks for your time designed for writing It .Wow so amazing, I am flattered with all the wonderful information I have got it This content is written very well. Your use of formatting when making your points makes your observations very clear and easy to understand. If you want academic writing related help you can take any best essay writing service from internet.Thank you.

    ReplyDelete
    Replies

    1. This blog is very attraction to me .I really like this article and your writing skill is very fantastic and beautiful . thanks a lot for the good language path of exile boosting

      Delete
  2. This is such an awesome asset, to the point that you are giving and you give it away for nothing.our article has piqued t to be very difficult for learners much like me. However, you have made it very easy for me to fully grasp and I now have in mind the correct thing. Your continued reputation as one of the top experts on this topic may be increased through words with appreciation from visitors like me. Thanks, again. I definitely enjoying every little bit of it. It is a great site and nice share. I want to thank you. Good job! You guys do a great blog, and have some great contents. Keep up the good work. site

    ReplyDelete
  3. This blog is very attraction to me .I really like this article and your writing skill is very fantastic and beautiful . thanks a lot for the good language Mattress Store Denver

    ReplyDelete
  4. Would love to always get updated outstanding blog ! 借錢

    ReplyDelete
  5. Thanks for the blog filled with so many information. Stopping by your blog helped me to get what I was looking for. Now my task has become as easy as ABC.借錢


    ReplyDelete
  6. The way you write, you are really a professional blogger. 借錢網

    ReplyDelete
  7. There is so much in this article that I would never have thought of on my own. Your content gives readers things to think about in an interesting way.buyitcert review

    ReplyDelete
  8. incredible article distributed here by you. i've for a long while been itching to adapt new things with respect to this subject, and i have unquestionably adapted new things today. Mattress Store Portland

    ReplyDelete
  9. There is so much in this article that I would never have thought of on my own. Your content gives readers things to think about in an interesting way.Mattress Sales Austin

    ReplyDelete


  10. This is such an awesome asset, to the point that you are giving and you give it away for nothing.our article has piqued a lot of positive interest. aws certification cost

    ReplyDelete
  11. incredible article distributed here by you. i've for a long while been itching to adapt new things with respect to this subject, and i have unquestionably adapted new things today. 借現金

    ReplyDelete


  12. What a well written and compassionate article. I found your thoughts and wisdom to be encouraging and helpful. DIY craft

    ReplyDelete
  13. Totally incredible posting! Heaps of valuable data and motivation, both of which we all need!Relay value your work. poe market

    ReplyDelete
  14. I really loved reading your blog. It was very well authored and easy to undertand. Unlike additional blogs I have read which are really not tht good. https://www.gaming4ez.com/FFXIV_Gil/ffxiv-gil

    ReplyDelete
  15. I really loved reading your blog. It was very well authored and easy to undertand. Unlike additional blogs I have read which are really not tht good. Mattress Fort Worth

    ReplyDelete
  16. Good site! I really love how it is simple on my eyes and the data are well written. I’m wondering how I might be notified whenever a new post has been made. I have subscribed to your RSS which must do the trick! Have a great day! comptia a+ exam cost

    ReplyDelete
  17. I think this is an informative post and it is very beneficial and knowledgeable. Therefore, I would like to thank you for the endeavors that you have made in writing this article. All the content is absolutely well-researched. Thanks. mcsa server 2016

    ReplyDelete
  18. There is so much in this article that I would never have thought of on my own. Your content gives readers things to think about in an interesting way.借錢

    ReplyDelete
  19. This blog is very attraction to me .I really like this article and your writing skill is very fantastic and beautiful . thanks a lot for the good language   aws certified developer associate

    ReplyDelete

  20. This would be the appropriate blog for anybody who really wants to find out about this topic. You are aware of so much its practically difficult to argue with you (not too I really would want…HaHa). You certainly put a brand new spin on the topic thats been revealed for years. Excellent stuff, just excellent! network+ salary

    ReplyDelete
  21. Positive website. I have read a few of the articles on your website now, and I really like your style. Thanks a million and please keep up the effective work. 借錢

    ReplyDelete
  22. You make so many great points here that I read your article a couple of times. Your views are in accordance with my own for the most part. This is great content for your readers. 快速借錢

    ReplyDelete
  23. Outstanding article! I want people to know just how good this information is in your article. Your views are much like my own concerning this subject. I will visit daily your blog because I know. It may be very beneficial for me.cism exam cost

    ReplyDelete
  24. This is such an awesome asset, to the point that you are giving and you give it away for nothing.our article has piqued a lot of positive interest. I can see why since you have done such a good job of making it interesting. Ikea Papasan chairs

    ReplyDelete
  25. incredible article distributed here by you. i've for a long while been itching to adapt new things with respect to this subject, and i have unquestionably adapted new things today.For more information click here

    ReplyDelete
  26. The way you write, you are really a professional blogger. For more information Click here

    ReplyDelete
  27. What a well written and compassionate article. I found your thoughts and wisdom to be encouraging and helpful,for more information Click here

    ReplyDelete
  28. Excellent read, I just passed this onto a colleague who was doing a little research on that. And he actually bought me lunch because I found it for him smile So let me rephrase that. For more information Click here

    ReplyDelete


  29. Excellent read, I just passed this onto a colleague who was doing a little research on that. And he actually bought me lunch because I found it for him smile So let me rephrase that.For more information click here

    ReplyDelete
  30. incredible article distributed here by you. i've for a long while been itching to adapt new things with respect to this subject, and i have unquestionably adapted new things today. For more information Visit here

    ReplyDelete
  31. This is such an awesome asset, to the point that you are giving and you give it away for nothing.our article has piqued a lot of positive interest. click here

    ReplyDelete
  32. What a well written and compassionate article. I found your thoughts and wisdom to be encouraging and helpful. click herex

    ReplyDelete
  33. The way you write, you are really a professional blogger. 急借錢

    ReplyDelete
  34. This is such an awesome asset, to the point that you are giving and you give it away for nothing.our article has piqued a lot of positive interest. 小額借款

    ReplyDelete


  35. What a well written and compassionate article. I found your thoughts and wisdom to be encouraging and helpful. 快速借貸

    ReplyDelete
  36. This is certainly as well a really good posting we seriously experienced looking through. It is far from on a daily basis we have risk to check out a little something.wedding anniversary game ideas

    ReplyDelete
  37. incredible article distributed here by you. i've for a long while been itching to adapt new things with respect to this subject, and i have unquestionably adapted new things today. esr sr01

    ReplyDelete
  38. This is such an awesome asset, to the point that you are giving and you give it away for nothing.our article has piqued a lot of positive interest. Suicide Cleanup colorado

    ReplyDelete
  39. I respect this article for the very much investigated substance and magnificent wording. I got so included in this material that I couldn't quit perusing. I am awed with your work and aptitude. Much obliged to you to such an extent.먹튀

    ReplyDelete
  40. incredible article distributed here by you. i've for a long while been itching to adapt new things with respect to this subject, and i have unquestionably adapted new things today. Visit Here

    ReplyDelete
  41. incredible article distributed here by you. i've for a long while been itching to adapt new things with respect to this subject, and i have unquestionably adapted new things today. Visit Here

    ReplyDelete
  42. Excellent read, I just passed this onto a colleague who was doing a little research on that. And he actually bought me lunch because I found it for him smile So let me rephrase that. 小額借款

    ReplyDelete
  43. It’s really a nice and useful piece of information. I am glad that you shared this useful information with us. Please keeps us to date like this .thank you for sharing.Oni Seed Co Seeds

    ReplyDelete
  44. I think this is an informative post and it is very beneficial and knowledgeable. Therefore, I would like to thank you for the endeavors that you have made in writing this article. All the content is absolutely well-researched. Thanks. camaro rims

    ReplyDelete
  45. Outstanding article! I want people to know just how good this information is in your article. Your views are much like my own concerning this subject. I will visit daily your blog because I know. It may be very beneficial for me. 快速借貸

    ReplyDelete
  46. This blog is very attraction to me .I really like this article and your writing skill is very fantastic and beautiful . thanks a lot for the good language 借款

    ReplyDelete
  47. Totally incredible posting! Heaps of valuable data and motivation, both of which we all need!Relay value your work judi online

    ReplyDelete
  48. This is such an awesome asset, to the point that you are giving and you give it away for nothing.our article has piqued a lot of positive interest. Click This Link
    Click Here
    Website Link
    For More Information
    Learn More Here
    Visit Website

    ReplyDelete
  49. I think this is an informative post and it is very beneficial and knowledgeable. Therefore, I would like to thank you for the endeavors that you have made in writing this article. All the content is absolutely well-researched. Thanks. dogs for sale

    ReplyDelete
  50. This blog is very attraction to me .I really like this article and your writing skill is very fantastic and beautiful . thanks a lot for the good language Visit here

    ReplyDelete
  51. I think this is an informative post and it is very beneficial and knowledgeable. 먹튀검증
    스포츠중계
    안전놀이터
    꽁머니

    ReplyDelete
  52. What a well written and compassionate article. I found your thoughts and wisdom to be encouraging and helpful. aodhan wheels

    ReplyDelete
  53. There is noticeably a bundle to know about this. I assume you made certain nice points in features also . fuel maverick

    ReplyDelete
  54. Good site! I really love how it is simple on my eyes and the data are well written. I’m wondering how I might be notified whenever a new post has been made.daily mail us

    ReplyDelete
  55. Outstanding article! I want people to know just how good this information is in your article. Your views are much like my own concerning this subject. I will visit daily your blog because I know. It may be very beneficial for me. Biker leather jacket

    ReplyDelete
  56. What a well written and compassionate article. I found your thoughts and wisdom to be encouraging and helpful. 小額信貸

    ReplyDelete
  57. Outstanding article! I want people to know just how good this information is in your article. Your views are much like my own concerning this subject. I will visit daily your blog because I know. It may be very beneficial for me. the best food for skin glow



    ReplyDelete
  58. There is noticeably a bundle to know about this. I assume you made certain nice points in features also . buy poe currency ps4

    ReplyDelete
  59. This blog is very attraction to me .I really like this article and your writing skill is very fantastic and beautiful . thanks a lot for the good language exalted orb price

    ReplyDelete
  60. Excellent read, I just passed this onto a colleague who was doing a little research on that. And he actually bought me lunch because I found it for him smile So let me rephrase that. Dating公司

    ReplyDelete
  61. It’s really a nice and useful piece of information. I am glad that you shared this useful information with us. Please keeps us to date like this .thank you for sharing.一對一配對收費

    ReplyDelete
  62. Totally incredible posting! Heaps of valuable data and motivation, both of which we all need!Relay value your work 約會公司

    ReplyDelete
  63. There is noticeably a bundle to know about this. I assume you made certain nice points in features also . Mingle2 Best Dating Site

    ReplyDelete
  64. What a well written and compassionate article. I found your thoughts and wisdom to be encouraging and helpful. business plural

    ReplyDelete

  65. Outstanding article! I want people to know just how good this information is in your article. Your views are much like my own concerning this subject. I will visit daily your blog because I know. It may be very beneficial for me. crypto forums

    ReplyDelete
  66. I respect this article for the very much investigated substance and magnificent wording. I got so included in this material that I couldn't quit perusing. I am awed with your work and aptitude. Much obliged to you to such an extent.!貸款

    ReplyDelete
  67. The way you write, you are really a professional blogger. !快速借款

    ReplyDelete
  68. It’s really a nice and useful piece of information. I am glad that you shared this useful information with us. Please keeps us to date like this .thank you for sharing.!當舖

    ReplyDelete
  69. The way you write, you are really a professional blogger. 貸款

    ReplyDelete
  70. This is such an awesome asset, to the point that you are giving and you give it away for nothing.our article has piqued a lot of positive interest. buy poe chaos orb

    ReplyDelete
  71. So happy to find good place to many here in the post, the writing is just great, thanks for the post. POE Currency

    ReplyDelete

  72. incredible article distributed here by you. i've for a long while been itching to adapt new things with respect to this subject, and i have unquestionably adapted new things today. buy poe items

    ReplyDelete
  73. This blog is very attraction to me .I really like this article and your writing skill is very fantastic and beautiful . thanks a lot for the good language !dubai investment real estate

    ReplyDelete
  74. There are many platforms available to learn foreign languages. but if you still search for the best platform then we will recommend you choose language scoop, where everyone can learn foreign languages very easily. Visit our website to learn more.

    ReplyDelete
  75. Good site! I really love how it is simple on my eyes and the data are well written. I’m wondering how I might be notified whenever a new post has been made.https://cpapamazon.com/apap-machine

    ReplyDelete
  76. I think this is an informative post and it is very beneficial and knowledgeable. Therefore, I would like to thank you for the endeavors that you have made in writing this article. All the content is absolutely well-researched. Thanks. 約會公司

    ReplyDelete
  77. Sunrise Top Movers and Packers Company helps client moving within UAE. Sunrise movers will make sure that you move with no worries relocation services.Top Movers and Packers Company in Dubai

    ReplyDelete
  78. Thanks for the best blog. it was very useful for me.keep sharing such ideas in the future as well.bipap breathing machine

    ReplyDelete
  79. I think this is an informative post and it is very beneficial and knowledgeable. Therefore, I would like to thank you for the endeavors that you have made in writing this article. All the content is absolutely well-researched. Thanks. 婚姻介紹

    ReplyDelete
  80. What a well written and compassionate article. I found your thoughts and wisdom to be encouraging and helpful. tga subcool seeds

    ReplyDelete
  81. Would love to always get updated outstanding blog !sleep apnea machine amazon

    ReplyDelete
  82. I got what you mean , thanks for posting .Woh I am happy to find this website through google.交友

    ReplyDelete
  83. This blog is very attraction to me .I really like this article and your writing skill is very fantastic and beautiful . thanks a lot for the good language profile

    ReplyDelete
  84. What a well written and compassionate article. I found your thoughts and wisdom to be encouraging and helpful. from the practice of family lawyers 15 craziest reasons for divorce

    ReplyDelete
  85. Whether you need a package of banking services that best suits offshore enterprises or high net-worth individuals, we’ll work one-on-one to create a bespoke suite of banking products to make sure you meet your financial needs.best business bank uae

    ReplyDelete
  86. Whether you need a package of banking services that best suits offshore enterprises or high net-worth individuals, we’ll work one-on-one to create a bespoke suite of banking products to make sure you meet your financial needs.best business bank uae

    ReplyDelete
  87. This is such an awesome asset, to the point that you are giving and you give it away for nothing.our article has piqued a lot of positive interest. I can see why since you have done such a good job of making it interesting. https://www.alazaherah.net/mangasteam/

    ReplyDelete
  88. From world-class facilities to value-added services, we offer broad incentives and unparalleled support to help your freezone and non-freezone company get off to a strong start. small business bank account uae

    ReplyDelete
  89. incredible article distributed here by you. i've for a long while been itching to adapt new things with respect to this subject, and i have unquestionably adapted new things today. apap machine cost

    ReplyDelete
  90. Totally incredible posting! Heaps of valuable data and motivation, both of which we all need!Relay value your work oni seed co seeds

    ReplyDelete
  91. What a well written and compassionate article. I found your thoughts and wisdom to be encouraging and helpful. Bitcoin Mixer

    ReplyDelete
  92. I think this is an informative post and it is very beneficial and knowledgeable. Therefore, I would like to thank you for the endeavors that you have made in writing this article. All the content is absolutely well-researched. Thanks. Bitcoin Mixer

    ReplyDelete
  93. The way you write, you are really a professional blogger. vmware certification cost

    ReplyDelete
  94. Outstanding article! I want people to know just how good this information is in your article. Your views are much like my own concerning this subject. I will visit daily your blog because I know. It may be very beneficial for me. https://mixmycrypto.io/

    ReplyDelete
  95. This is such an awesome asset, to the point that you are giving and you give it away for nothing.our article has piqued a lot of positive interest. security+ cost

    ReplyDelete
  96. What a well written and compassionate article. I found your thoughts and wisdom to be encouraging and helpful. Click Here

    ReplyDelete
  97. This is such an awesome asset, to the point that you are giving and you give it away for nothing.our article has piqued a lot of positive interest. Website

    ReplyDelete
  98. What a well written and compassionate article. I found your thoughts and wisdom to be encouraging and helpful. Click Here

    ReplyDelete
  99. I found it for him smile So let me rephrase that. esr cs15

    ReplyDelete
  100. What a well written and compassionate article. I found your thoughts and wisdom to be encouraging and helpful. fuel maverick 20x10

    ReplyDelete
  101. Outstanding article! I want people to know just how good this information is in your article. Your views are much like my own concerning this subject. I will visit daily your blog because I know. It may be very beneficial for me. f1r wheels for sale

    ReplyDelete
  102. I think this is an informative post and it is very beneficial and knowledgeable. Therefore, I would like to thank you for the endeavors that you have made in writing this article. All the content is absolutely well-researched. Thanks.cpap amazon

    ReplyDelete
  103. This is certainly as well a really good posting we seriously experienced looking through. It is far from on a daily basis we have risk to check out a little something.快速借貸

    ReplyDelete
  104. I found it for him smile So let me rephrase that. Bankofseeds

    ReplyDelete
  105. Excellent read, I just passed this onto a colleague who was doing a little research on that. And he actually bought me lunch because I found it for him smile So let me rephrase that. 貸款

    ReplyDelete
  106. Would love to always get updated outstanding blog !現金貸款

    ReplyDelete
  107. This is certainly as well a really good posting we seriously experienced looking through. It is far from on a daily basis we have risk to check out a little something.借錢

    ReplyDelete
  108. incredible article distributed here by you. i've for a long while been itching to adapt new things with respect to this subject, and i have unquestionably adapted new things today.indian visa for british citizens

    ReplyDelete
  109. Outstanding article! I want people to know just how good this information is in your article. Your views are much like my own concerning this subject. I will visit daily your blog because I know. It may be very beneficial for me. aodhan wheels for sale

    ReplyDelete
  110. Thanks for the best blog. it was very useful for me.keep sharing such ideas in the future as well.aws certification price

    ReplyDelete

Post a Comment

Popular posts from this blog

How to kill/exit iOS application on a button click programmatically

I had been practising below code to kill an iOS application. exit(0); But last week, my application was rejected by app store due to following reason: We found that your app includes a UI control for quitting the app. This is not in compliance with the iOS Human Interface Guidelines, as required by the App Store Review Guidelines . To avoid any such rebuff, suspend the application using following code snippet. UIApplication.shared.perform(#selector(NSXPCConnection.suspend)) Good news is that now my application is passed the  iOS Human Interface Guidelines and live on app store.

Interview question which I faced during FAANG interview

    Programming question given to me at  leetcode.      Given two strings representing very large integer numbers ("123" , "30") return a string        representing the sum of the two numbers ("153").     The above question can be rephrased as:-            Add two numbers represented by strings            Sum of two large numbers            Add Two Very Large Number (out of range)            How to add two string numbers             Solution in Swift programming language: func add (first: String , second: String ) {         var input1 = first         var input2 = second                  var firstArray = Array (first)         var secondArray = Array (second)                  //both inputs should have same number of characters         var differenceOfCharacter = 0         if firstArray. count > secondArray. count {             differenceOfCharacter = firstArray. count - secondArray. count             ( 0 ..< differenceOfCharacter). forEach