当前位置: 首页 > news >正文

ViewModifier/视图修饰符, ButtonStyle/按钮样式 的使用

1. ViewModifier 视图修饰符

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

import SwiftUI/// 默认按钮修饰符
struct DefaultButtonViewModifier: ViewModifier{let bcakgroundColor: Colorfunc body(content: Content) -> some View {content.foregroundColor(.white).frame(height: 55).frame(maxWidth: .infinity).background(bcakgroundColor).cornerRadius(10).shadow(radius: 10)}
}// 扩展 View
extension View {func withDefaultButtonFormatting(backgroundColor: Color = .blue) -> some View{modifier(DefaultButtonViewModifier(bcakgroundColor: backgroundColor))}
}/// 视图修饰符
struct ViewModifierBootcamp: View {var body: some View {VStack(spacing: 10) {Text("Hello,world!").font(.headline).withDefaultButtonFormatting(backgroundColor: .orange)Text("Hello,everyone!").font(.subheadline).withDefaultButtonFormatting()Text("Hello !!!").font(.title).withDefaultButtonFormatting(backgroundColor: .red)}.padding()}
}struct ViewModifierBootcamp_Previews: PreviewProvider {static var previews: some View {ViewModifierBootcamp()}
}

  1.2 效果图:

2. ButtonStyle 自定义按钮样式

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

import SwiftUI///  按下按钮样式
struct PressableButtonStyle: ButtonStyle{let scaledAmount: CGFloatinit(scaledAmount: CGFloat) {self.scaledAmount = scaledAmount}func makeBody(configuration: Configuration) -> some View {configuration.label// 缩放.scaleEffect(configuration.isPressed ? scaledAmount : 1.0)// 点亮度//.brightness(configuration.isPressed ? 0.05 : 0).opacity(configuration.isPressed ? 0.86 : 1)}
}/// 扩展 View
extension View{/// 按钮的样式func withPressableStyle(scaledAmount: CGFloat = 0.9) -> some View{buttonStyle(PressableButtonStyle(scaledAmount: scaledAmount))}
}/// 按钮样式
struct ButtonStyleBootcamp: View {var body: some View {Button {} label: {Text("Click Me").font(.headline).withDefaultButtonFormatting()}.withPressableStyle(scaledAmount: 0.86).padding(40)}
}struct ButtonStyleBootcamp_Previews: PreviewProvider {static var previews: some View {ButtonStyleBootcamp()}
}

  2.2 效果图:

http://www.lryc.cn/news/189319.html

相关文章:

  • 科技资讯|微软AR眼镜新专利曝光,可拆卸电池解决续航焦虑
  • idea系列---【上一次打开springboot项目还好好的,现在打开突然无法启动了】
  • 查询资源消耗
  • conda: error: argument COMMAND: invalid choice: ‘activate‘
  • 新鲜速递:Spring Cloud Alibaba环境在Spring Boot 3时代的快速搭建
  • 网络-网络状态网络速度
  • ACL访问控制列表的解析和配置
  • 记一次使用vue-markdown在vue中解析markdown格式文件,并自动生成目录大纲
  • 力扣每日一题35:搜索插入的位置
  • Iptabels的相关描述理解防火墙的必读文章
  • Maven 构建项目测试
  • 机器学习 - 似然函数:概念、应用与代码实例
  • LeetCode 热题 100-49. 字母异位词分组
  • TensorFlow入门(十九、softmax算法处理分类问题)
  • 刷题用到的非常有用的函数c++(持续更新)
  • 黑客技术(网络安全)——自学思路
  • lNmp安装:
  • Fisher辨别分析
  • 【Zookeeper专题】Zookeeper选举Leader源码解析
  • 机器学习之自训练协同训练
  • ubuntu 通过apt-get快速安装 docker
  • C++医院影像科PACS源码:三维重建、检查预约、胶片打印、图像处理、测量分析等
  • 企业聊天应用程序使用 Kubernetes
  • 记录用命令行将项目打包成war包
  • Linux基础知识笔记
  • Laya3.0 入门教程
  • 3D全景虚拟样板间展销系统扩展用户市场范围
  • 如何编写lua扩展库
  • Java List 中存不同的数据类型
  • pyqt5:openpyxl 读取 Excel文件,显示在 QTableWidget 中