小组件互动:点我有惊喜!

摘要

小组件点一下,自动跳转到App,让互动更加便捷。使用Widget对话框,勾起APP,特定自动跳转,让你的体验更加顺畅。

正文

IOS小组件(7):小组件点一下互动

前言

  前边大家好像把握了完成一个小组件所必须的一切专业技能,默认设置状况下桌面上点一下小组件,也一切正常自动跳转到App中。下面我们一起来看一下,小组件是怎么保证点一下自动跳转到App的。

点一下交互技术

点一下Widget对话框勾起APP开展互动特定自动跳转适用二种方法:

  • widgetURL:点一下地区是Widget的全部地区,合适原素、逻辑性简易的小构件
  • Link:根据Link装饰,容许让页面上不一样原素造成点一下回应

Widget适用三种动态显示,分别是systemSmall、 systemMedium、systemLarge,在其中:

  • systemSmall只有用widgetURL修饰符完成URL传送接受
  • systemMedium、systemLarge可以用Link或是 widgetUrl解决

widgetURL和Link应用特性

  • widgetURL一个合理布局中只有一个起效
  • Link一个合理布局中能够有好几个
  • Link能够嵌入widgetURL, widgetURL能够每日签到Link
  • Link能够嵌入Link

点一下互动编码检测

如果是应用SwifitUI的工程项目,监视小组件点一下编码以下

@main
struct Training1App: App {
    var body: some Scene {
        WindowGroup {
            ContentView().onOpenURL(perform: { url in
                print("点一下了小组件 absoluteString:\(url.absoluteString)")
                print("点一下了小组件 relativeString:\(url.relativeString)")
            })
        }
    }
}

新号部件点一下互动

 VStack {
    Spacer()
    Link(destination: URL(string: "small/link")!) {
        Text("一般文字")
            .font(.system(size: 15))    // 字体样式
            .foregroundColor(Color(hexString: "#FF0000"))
    }
    Spacer()
    Text(entry.date, style: .timer)
        .multilineTextAlignment(.center)
        .background(Color(hexString: "#FFFF00"))
        .widgetURL(URL(string: "small/widgeturl_text")!)
    Spacer()
}
.frame(maxWidth: .infinity, maxHeight: .infinity)
.background(Color(hexString: "#00FFFF"))
.widgetURL(URL(string: "small/wigeturl_root"))

結果以下:无论点哪一个View都只发生了一个,并且根合理布局的无效了,Link就失灵,因此新号部件只有应用widgetURL的方法。

新号部件常见点一下交互技术

VStack {
    Spacer()
    Text("一般文字")
        .font(.system(size: 15))    // 字体样式
        .foregroundColor(Color(hexString: "#FF0000"))
    Spacer()
    Text(entry.date, style: .timer)
        .multilineTextAlignment(.center)
        .background(Color(hexString: "#FFFF00"))
    Spacer()
}
.frame(maxWidth: .infinity, maxHeight: .infinity)
.background(Color(hexString: "#00FFFF"))
.widgetURL(URL(string: "small/wigeturl_root"))

結果:widgetURL起效

中等尺寸部件点一下互动1

VStack {
    Link(destination: URL(string: "medium/link_text1")!) {
        Text("一般文字")
            .font(.system(size: 15))    // 字体样式
            .foregroundColor(Color(hexString: "#FF0000"))
    }
    Link(destination: URL(string: "medium/link_text2")!) {
        Text(entry.date, style: .timer)
            .multilineTextAlignment(.center)
            .background(Color(hexString: "#FFFF00"))
    }
    Text("一般文字2")
        .font(.system(size: 15))    // 字体样式
        .foregroundColor(Color(hexString: "#FF0000"))
        .widgetURL(URL(string: "medium/widgeturl_text"))
}
.frame(maxWidth: .infinity, maxHeight: .infinity)
.background(Color(hexString: "#00FFFF"))
.widgetURL(URL(string: "medium/widgeturl_root"))

各自点一下三个子View和根合理布局(空白)結果:widgetURL只有一个起效,Link都起效

中等尺寸部件点一下互动2

VStack {
    Link(destination: URL(string: "medium/link_text1")!) {
        Text("一般文字")
            .font(.system(size: 15))    // 字体样式
            .foregroundColor(Color(hexString: "#FF0000"))
    }
    Link(destination: URL(string: "medium/link_text2")!) {
        Text(entry.date, style: .timer)
            .multilineTextAlignment(.center)
            .background(Color(hexString: "#FFFF00"))
    }
    Text("一般文字2")
        .font(.system(size: 15))    // 字体样式
        .foregroundColor(Color(hexString: "#FF0000"))
}
.frame(maxWidth: .infinity, maxHeight: .infinity)
.background(Color(hexString: "#00FFFF"))
.widgetURL(URL(string: "medium/widgeturl_root"))

各自点一下三个子View和根合理布局(空白)結果:好几个Link起效,widgerURL嵌入Link起效

中等尺寸部件点一下互动3

Link(destination: URL(string: "medium/widgeturl_root")!) {
    VStack {
        Link(destination: URL(string: "medium/link_text1")!) {
            Text("一般文字")
                .font(.system(size: 15))    // 字体样式
                .foregroundColor(Color(hexString: "#FF0000"))
        }
        Link(destination: URL(string: "medium/link_text2")!) {
            Text(entry.date, style: .timer)
                .multilineTextAlignment(.center)
                .background(Color(hexString: "#FFFF00"))
        }
        Text("一般文字2")
            .font(.system(size: 15))    // 字体样式
            .foregroundColor(Color(hexString: "#FF0000"))
    }
    .frame(maxWidth: .infinity, maxHeight: .infinity)
    .background(Color(hexString: "#00FFFF"))
}

运作結果:Link嵌入Link起效

总结

  文中详细介绍了小组件点一下互动的二种方法,widgetURL和Link,根据测试程序了解了实际的应用和组成状况。到此,小组件全部步骤上的技术性点都解读完后。事后也有两个一部分:App与小组件信息共享,N个小组件如何适用。

关注不迷路

扫码下方二维码,关注宇凡盒子公众号,免费获取最新技术内幕!

温馨提示:如果您访问和下载本站资源,表示您已同意只将下载文件用于研究、学习而非其他用途。
文章版权声明 1、本网站名称:宇凡盒子
2、本站文章未经许可,禁止转载!
3、如果文章内容介绍中无特别注明,本网站压缩包解压需要密码统一是:yufanbox.com
4、本站仅供资源信息交流学习,不保证资源的可用及完整性,不提供安装使用及技术服务。点此了解
5、如果您发现本站分享的资源侵犯了您的权益,请及时通知我们,我们会在接到通知后及时处理!提交入口
0

评论0

请先

站点公告

🚀 【宇凡盒子】全网资源库转储中心

👉 注册即送VIP权限👈

👻 全站资源免费下载✅,欢迎注册!

记得 【收藏】+【关注】 谢谢!~~~

立即注册
没有账号?注册  忘记密码?

社交账号快速登录