当前位置: 首页 > 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 效果图:

相关文章:

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

1. ViewModifier 视图修饰符 1.1 创建默认按钮视图修饰符 ViewModifierBootcamp.swift import SwiftUI/// 默认按钮修饰符 struct DefaultButtonViewModifier: ViewModifier{let bcakgroundColor: Colorfunc body(content: Content) -> some View {content.foregroundColor…...

科技资讯|微软AR眼镜新专利曝光,可拆卸电池解决续航焦虑

微软正在深入研究增强现实(AR)领域,最近申请了一项“热插拔电池”相关专利。该专利于 2023 年 10 月 5 日发布,描述了采用模块化设计的 AR 眼镜,热插拔电池放置在了镜腿部分,可以直接拿下替换,对…...

idea系列---【上一次打开springboot项目还好好的,现在打开突然无法启动了】

问题 昨天走的时候项目还能正常启动,今天来了之后突然报下面的错误: Error:Kotlin: Module was compiled with an incompatible version of Kotlin. The binary version of its metadata is 1.7.1, expected version is 1.1.16. 解决方案 点击 idea: Bui…...

查询资源消耗

import subprocess def get_cpu_usage(pid, duration): output subprocess.check_output([‘pidstat’, ‘-d’, ‘-p’, str(pid), ‘1’, str(duration)]).decode(‘utf-8’) lines output.strip().split(’\n’) cpu_usage [] for line in lines[4:]: fields line.spli…...

conda: error: argument COMMAND: invalid choice: ‘activate‘

参考:https://github.com/conda/conda/issues/13022 输入后重启terminal即可...

新鲜速递:Spring Cloud Alibaba环境在Spring Boot 3时代的快速搭建

了解 首先,Spring Cloud Alibaba使用的是Nacos作为服务注册和服务发现的中间件。 能力在提供者那里,而消费者只需知道提供者提供哪些服务,而无需关心提供者在哪里,实际调用过程如下图 准备工作 1、需要下载并安装Nacos最新版…...

网络-网络状态网络速度

文章目录 前言一、网络状态二、网络速度 前言 本文主要记录如何监听网络状态和网络速度。 一、网络状态 获取当前网络状态: navigator.onLine // true:在线 false:离线监听事件:online(联网) 和 offline(断网) windo…...

ACL访问控制列表的解析和配置

ACL的解析 个人简介 ACL - Access Control List 访问控制列表 策略 ------行为 允许/拒绝 ACL --包含两种 标准ACL 扩展ACL 标准ACL:只能针对源IP地址做限制 针对路由条目的限制 -路由策略 思科编号:1-99之间或1300-1999 扩展ACL:针对…...

记一次使用vue-markdown在vue中解析markdown格式文件,并自动生成目录大纲

先上效果图 如图所示,在网页中,能直接解析markdown文档,并且生成目录大纲,也支持点击目录标题跳转到对应栏目中,下面就来讲讲是如何实现此功能的。 1、下载vue-markdown yarn add vue-markdown 2、在页面中渲染markdo…...

力扣每日一题35:搜索插入的位置

题目描述: 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 示例 1: 输入: nums [1,3,5,6], target 5…...

Iptabels的相关描述理解防火墙的必读文章

Iptabels是与Linux内核集成的包过滤防火墙系统,几乎所有的linux发行版本都会包含Iptables的功能。如果 Linux 系统连接到因特网或 LAN、服务器或连接 LAN 和因特网的代理服务器, 则Iptables有利于在 Linux 系统上更好地控制 IP 信息包过滤和防火墙配置。…...

Maven 构建项目测试

在上一章节中我们学会了如何使用 Maven 创建 Java 应用。接下来我们要学习如何构建和测试这个项目。 进入 C:/MVN 文件夹下&#xff0c;打开 consumerBanking 文件夹。你将看到有一个 pom.xml 文件&#xff0c;代码如下&#xff1a; <project xmlns"http://maven.apa…...

机器学习 - 似然函数:概念、应用与代码实例

目录 一、概要二、什么是似然函数数学定义似然与概率的区别重要性举例 三、似然函数与概率密度函数似然函数&#xff08;Likelihood Function&#xff09;定义例子 概率密度函数&#xff08;Probability Density Function, PDF&#xff09;定义 区别与联系 四、最大似然估计&am…...

LeetCode 热题 100-49. 字母异位词分组

题目描述 给你一个字符串数组&#xff0c;请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。 字母异位词 是由重新排列源单词的所有字母得到的一个新单词。 示例 1: 输入: strs [“eat”, “tea”, “tan”, “ate”, “nat”, “bat”] 输出: [[“bat”],[“n…...

TensorFlow入门(十九、softmax算法处理分类问题)

softmax是什么? Sigmoid、Tanh、ReLU等激活函数,输出值只有两种(0、1,或-1、1或0、x),而实际现实生活中往往需要对某一问题进行多种分类。例如之前识别图片中模糊手写数字的例子,这个时候就需要使用softmax算法。 softmax的算法逻辑 如果判断输入属于某一个类的概率大于属于其…...

刷题用到的非常有用的函数c++(持续更新)

阅读导航 字符串处理类一、stoi()&#xff08;将字符串转换为整数类型&#xff09;二、to_string()&#xff08;将整数类型转换为字符串类型&#xff09;三、stringstream函数&#xff08;将一个字符串按照指定的分隔符进行分词&#xff09; 字符串处理类 一、stoi()&#xff…...

黑客技术(网络安全)——自学思路

如果你想自学网络安全&#xff0c;首先你必须了解什么是网络安全&#xff01;&#xff0c;什么是黑客&#xff01;&#xff01; 1.无论网络、Web、移动、桌面、云等哪个领域&#xff0c;都有攻与防两面性&#xff0c;例如 Web 安全技术&#xff0c;既有 Web 渗透2.也有 Web 防…...

lNmp安装:

一、LNMP LNMP架构是目前成熟的企业网站应用模式之一&#xff0c;指的是协同工作的一整套系统和相关软件&#xff0c; 能够提供动态Web站点服务及其应用开发环境。LNMP是一个缩写词&#xff0c;具体包括Linux操作系统、nginx网站服务器、MySQL数据库服务器、 PHP&#xff08;或…...

Fisher辨别分析

问题要求 在UCI数据集上的Iris和Sonar数据上验证算法的有效性。训练和测试样本有三种方式&#xff08;三选一&#xff09;进行划分&#xff1a; &#xff08;一&#xff09; 将数据随机分训练和测试&#xff0c;多次平均求结果 &#xff08;二&#xff09;K折交叉验证 &…...

【Zookeeper专题】Zookeeper选举Leader源码解析

目录 前言阅读建议课程内容一、ZK Leader选举流程回顾二、源码流程图三、Leader选举模型图 学习总结 前言 为什么要看源码&#xff1f;说实在博主之前看Spring源码之前没想过这个问题。因为我在看之前就曾听闻大佬们说过【JavaCoder三板斧&#xff1a;Java&#xff0c;Mysql&a…...

DOM DocumentImpl:深入解析文档对象模型的核心实现

DOM DocumentImpl:深入解析文档对象模型的核心实现 引言 在Web开发领域,DOM(文档对象模型)是前端开发的基础,它允许开发者通过JavaScript操作HTML文档。DOM DocumentImpl是DOM的核心实现之一,它提供了丰富的API来操作文档结构。本文将深入解析DOM DocumentImpl,帮助开…...

Python 3 CGI 编程

Python 3 CGI 编程 引言 随着互联网技术的不断发展,Web应用程序的需求日益增长。Python作为一种功能强大的编程语言,因其简洁的语法和丰富的库支持,在Web开发领域得到了广泛的应用。CGI(Common Gateway Interface,通用网关接口)是一种网络程序,它允许Web服务器执行外部…...

给小米CyberGear电机找个‘家’:用3D打印限位器解决断电丢零位问题(附STL文件)

给小米CyberGear电机打造3D打印限位器&#xff1a;硬件方案解决断电丢零位难题 在机器人开发领域&#xff0c;小米CyberGear和灵足电机凭借其高性价比和出色性能&#xff0c;已成为众多创客和工程师的首选。然而&#xff0c;这类电机在实际应用中存在一个普遍痛点——断电后零…...

WarcraftHelper:突破经典游戏限制的焕新体验工具

WarcraftHelper&#xff1a;突破经典游戏限制的焕新体验工具 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 当你在4K显示器上启动《魔兽争霸III》时&…...

01-第1章-概述与快速开始

第 1 章&#xff1a;概述与快速开始 1.1 sfsDb 简介 sfsDb 是一款专为工业物联网&#xff08;IIoT&#xff09;和边缘计算场景设计的纯 Go 语言嵌入式数据库。它基于 LevelDB 构建&#xff0c;提供了无锁事务系统、高效索引管理、时序数据处理和加密存储等功能。 核心特性 纯…...

AI驯服“人造太阳”:等离子体物理的智能革命

AI驯服“人造太阳”&#xff1a;等离子体物理的智能革命 引言 可控核聚变&#xff0c;被誉为人类能源的“终极梦想”。然而&#xff0c;驾驭上亿度的等离子体——这团“人造太阳”&#xff0c;其复杂性与不稳定性让科学家们挑战了数十年。如今&#xff0c;人工智能&#xff08…...

从硬件差异到数据兼容:速腾RS与Velodyne雷达的‘intensity‘字段深度解析

从硬件差异到数据兼容&#xff1a;速腾RS与Velodyne雷达的intensity字段深度解析 激光雷达作为自动驾驶和机器人感知的核心传感器&#xff0c;其数据格式的标准化程度直接影响算法开发的效率。速腾&#xff08;RoboSense&#xff09;与Velodyne作为两大主流厂商&#xff0c;硬件…...

十分钟搞定登录原型:用快马AI快速生成全站登录应用前端与后端

今天想和大家分享一个快速搭建全站登录应用原型的经验。最近在做一个新项目&#xff0c;需要验证登录模块的流程设计&#xff0c;传统开发方式至少要花一两天时间配置前后端环境&#xff0c;但这次尝试用InsCode(快马)平台的AI生成功能&#xff0c;十分钟就搞定了可交互的原型。…...

wps的VBA小tips1

在WPS/Excel的JS宏&#xff08;以及VBA&#xff09;里&#xff0c; Value2 是比 Value 更常用、更可靠的属性&#xff0c;主要有这几个核心原因&#xff1a;1. 避免格式干扰- Value 会受单元格显示格式影响&#xff1a;如果单元格设置了日期、货币、百分比等格式&#xff0c…...

MinIO权限配置踩坑实录:从‘策略不生效’到‘安全加固’的完整排错指南

MinIO权限配置实战&#xff1a;从策略失效到精细化管控的深度解析 那天下午&#xff0c;运维团队突然收到业务部门的紧急反馈——用户A无法从指定存储桶下载关键报表文件。这个看似简单的权限问题&#xff0c;却让我们团队花了整整三个小时排查。本文将还原这次故障排查的全过程…...