码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • ViewModifier/视图修饰符, ButtonStyle/按钮样式 的使用


    1. ViewModifier 视图修饰符

      1.1 创建默认按钮视图修饰符 ViewModifierBootcamp.swift

    1. import SwiftUI
    2. /// 默认按钮修饰符
    3. struct DefaultButtonViewModifier: ViewModifier{
    4. let bcakgroundColor: Color
    5. func body(content: Content) -> some View {
    6. content
    7. .foregroundColor(.white)
    8. .frame(height: 55)
    9. .frame(maxWidth: .infinity)
    10. .background(bcakgroundColor)
    11. .cornerRadius(10)
    12. .shadow(radius: 10)
    13. }
    14. }
    15. // 扩展 View
    16. extension View {
    17. func withDefaultButtonFormatting(backgroundColor: Color = .blue) -> some View{
    18. modifier(DefaultButtonViewModifier(bcakgroundColor: backgroundColor))
    19. }
    20. }
    21. /// 视图修饰符
    22. struct ViewModifierBootcamp: View {
    23. var body: some View {
    24. VStack(spacing: 10) {
    25. Text("Hello,world!")
    26. .font(.headline)
    27. .withDefaultButtonFormatting(backgroundColor: .orange)
    28. Text("Hello,everyone!")
    29. .font(.subheadline)
    30. .withDefaultButtonFormatting()
    31. Text("Hello !!!")
    32. .font(.title)
    33. .withDefaultButtonFormatting(backgroundColor: .red)
    34. }
    35. .padding()
    36. }
    37. }
    38. struct ViewModifierBootcamp_Previews: PreviewProvider {
    39. static var previews: some View {
    40. ViewModifierBootcamp()
    41. }
    42. }

      1.2 效果图:

    2. ButtonStyle 自定义按钮样式

      2.1 创建按下按钮样式,ButtonStyleBootcamp.swift

    1. import SwiftUI
    2. /// 按下按钮样式
    3. struct PressableButtonStyle: ButtonStyle{
    4. let scaledAmount: CGFloat
    5. init(scaledAmount: CGFloat) {
    6. self.scaledAmount = scaledAmount
    7. }
    8. func makeBody(configuration: Configuration) -> some View {
    9. configuration.label
    10. // 缩放
    11. .scaleEffect(configuration.isPressed ? scaledAmount : 1.0)
    12. // 点亮度
    13. //.brightness(configuration.isPressed ? 0.05 : 0)
    14. .opacity(configuration.isPressed ? 0.86 : 1)
    15. }
    16. }
    17. /// 扩展 View
    18. extension View{
    19. /// 按钮的样式
    20. func withPressableStyle(scaledAmount: CGFloat = 0.9) -> some View{
    21. buttonStyle(PressableButtonStyle(scaledAmount: scaledAmount))
    22. }
    23. }
    24. /// 按钮样式
    25. struct ButtonStyleBootcamp: View {
    26. var body: some View {
    27. Button {
    28. } label: {
    29. Text("Click Me")
    30. .font(.headline)
    31. .withDefaultButtonFormatting()
    32. }
    33. .withPressableStyle(scaledAmount: 0.86)
    34. .padding(40)
    35. }
    36. }
    37. struct ButtonStyleBootcamp_Previews: PreviewProvider {
    38. static var previews: some View {
    39. ButtonStyleBootcamp()
    40. }
    41. }

      2.2 效果图:

  • 相关阅读:
    大模型日报 2024-07-12
    为什么说 HashMap 是无序的
    Day53:图论 岛屿数量 岛屿的最大面积
    Linux16 ---共享内存、操作函数、使用示例
    SpringSecurity6从入门到上天系列第六篇:解决这个问题为什么在引入SpringSecurity之后所有的请求都需要先做登录认证才可以进行访问呢
    【C语言】用单链表实现一个二进制数加1的运算。
    【强化学习论文合集】AAAI-2021 强化学习论文
    【SpringMVC】Controller中映射方法的参数解析过程
    Linux性能优化--性能工具:特定进程CPU
    网络虚拟化
  • 原文地址:https://blog.csdn.net/u011193452/article/details/133774981
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号