swiftui中使用icon图标时,让中间部分不透明显示

在使用了Image(systemName: "plus.circle.fill")这个视图组件后,发现中间的加号竟然是透明的,但是我们想要的是不让它透明,该怎么做呢?

最简单的方式就是给这个图片设置一个白色的背景是不是就好了?我们可以尝试修改一下:

Swift 复制代码
Image(systemName: "plus.circle.fill")
                              .font(.title)
                              .background(Circle().fill(.white))

可以看到确实不透明了,但是这个按钮的周围怎么出现了白色的一个边框?这也不是我们想要的结果啊,好吧,确实不能这么简单的设置

还有一种方式,就是设置symbolRenderingMode渲染模式,将渲染模式设置为色盘模式:.symbolRenderingMode(.palette),然后自定义修改前景色和背景色:.foregroundStyle(.white, .blue),最后出现的效果就是:

Swift 复制代码
Image(systemName: "plus.circle.fill")
                              .font(.title)
                              .symbolRenderingMode(.palette)
                              .foregroundStyle(.white, .blue)

这么设置之后,就是我们想要的结果了:

相关推荐
盛夏绽放3 小时前
jQuery 知识点复习总览
前端·javascript·jquery
胡gh5 小时前
依旧性能优化,如何在浅比较上做文章,memo 满天飞,谁在裸奔?
前端·react.js·面试
大怪v5 小时前
超赞👍!优秀前端佬的电子布洛芬技术网站!
前端·javascript·vue.js
胡gh5 小时前
你一般用哪些状态管理库?别担心,Zustand和Redux就能说个10分钟
前端·面试·node.js
roamingcode7 小时前
Claude Code NPM 包发布命令
前端·npm·node.js·claude·自定义指令·claude code
码哥DFS7 小时前
NPM模块化总结
前端·javascript
灵感__idea7 小时前
JavaScript高级程序设计(第5版):代码整洁之道
前端·javascript·程序员
唐璜Taro8 小时前
electron进程间通信-IPC通信注册机制
前端·javascript·electron
陪我一起学编程9 小时前
创建Vue项目的不同方式及项目规范化配置
前端·javascript·vue.js·git·elementui·axios·企业规范
LinXunFeng9 小时前
Flutter - 详情页初始锚点与优化
前端·flutter·开源