AppleWatch开发入门四——Table视图的应用

简介: AppleWatch开发入门四——Table视图的应用

AppleWatch开发入门四——Table视图的应用


一、Watch上的Table


       WatchOS中的TableView和iOS中的TableView还是有很大的区别,在开发之前,首先我们应该明白WatchOS中的Table有哪些局限性和特点。下面几点是我总结WatchOS中Table的特殊之处:


1、Table只有行的概念,没有分区的概念,没有头尾视图的概念。


2、可以通过创建多个Table,来实现分区的效果。


3、因为Watch上是通过Gruop进行布局适应的,所以没有行高等设置。


4、Table没有代理,所有行的数据都是采用静态配置的方式,后面会介绍。


5、点击Table中的行触发的方法,是通过重写Interface中的方法来实现的。


二、创建一个Table


       在storyBoard中拖入你的Table,如下:

image.png

     


在Table上拉两个label:


image.png


每一个Table中包含一个TableRowController,实际上我们Table上的控件都是通过这个TableRowController进行管理的,因此如果我们需要在代码中控制TableRow上的内容,我们需要创建一个文件作为Table的TableRowController:


image.png


将storyBoard中TableRowController的类修改为我们创建的类并指定一个identifier:


image.pngimage.png

             




然后,我们将两个label关联到TableRowController中:


import WatchKit

class TableRowController: NSObject {


   @IBOutlet var numberLabel: WKInterfaceLabel!

   @IBOutlet var titleLabel: WKInterfaceLabel!

}


将Table关联到interfaceController中:


class InterfaceControllerMain: WKInterfaceController {

 

   @IBOutlet var Table: WKInterfaceTable!


}


下面,我们开始在interface中对Table做相关配置,首先我们可以先观察一下WKInterfaceTable中有哪些方法和属性:


public class WKInterfaceTable : WKInterfaceObject {

   //设置行的类型,数组中对应存放行的类型,数组元素的个数,就是行数

   /*

   通过这个方法,我们可以创建每一行样式都不同的table,行的类型

   实际上就是我们刚才用到的TableRowController,我们可以进行自定义

   */

   public func setRowTypes(rowTypes: [String])

   //设置行数和类型 用于创建单一行类型的table

   public func setNumberOfRows(numberOfRows: Int, withRowType rowType: String) // repeating row name

   //这个get方法获取行数,用于我们遍历table中的行,进行内容设置

   public var numberOfRows: Int { get }

   //这个方法会返回某一行,我们可以获取到后进行内容设置

   public func rowControllerAtIndex(index: Int) -> AnyObject?

   //插入一行

   public func insertRowsAtIndexes(rows: NSIndexSet, withRowType rowType: String)

   //删除一行

   public func removeRowsAtIndexes(rows: NSIndexSet)

   //滑动到某一行

   public func scrollToRowAtIndex(index: Int)

}


了解了上面的方法,可以看出,WatchOS的Table配置非常简单易用,例如我们如下配置:


@IBOutlet var Table: WKInterfaceTable!


   override func awakeWithContext(context: AnyObject?) {

       super.awakeWithContext(context)

       let dic:Dictionary<String,String> = ["中国建设银行":"¥1000","中国农业银行":"¥5000","中国银行":"20000","招商银行":"¥401","中国邮政储蓄":"1100"]

       //设置行数与类型

       Table.setNumberOfRows(dic.count, withRowType: "TableRowController")

       //遍历进行设置

       let titleArray:Array<String> = Array(dic.keys)

       for var i=0 ; i < dic.count ; i++ {

           let row:TableRowController = Table.rowControllerAtIndex(i) as! TableRowController

           row.titleLabel.setText(titleArray[i])

           row.numberLabel.setText(dic[titleArray[i]])

           row.numberLabel.setTextColor(UIColor.grayColor())

       }

       // Configure interface objects here.

   }


这样一个展示银行卡余额的界面我们就创建完成了,效果如下:


image.png


三、关于Table的点击事件


       上面我们提到,Table没有所谓代理方法,点击row的时候,我们也是通过两种方式进行逻辑跳转的,一种是在storyBoard中,我们通过拉线跳转,这时如需传值,我们需在interface中实现如下方法:


public func contextForSegueWithIdentifier(segueIdentifier: String, inTable table: WKInterfaceTable, rowIndex: Int) -> AnyObject?

       另一种方式,我们可以重写实现InterfaceController中的如下方法,来处理Table的点击事件:


public func table(table: WKInterfaceTable, didSelectRowAtIndex rowIndex: Int)

       无论哪种方式,我们都可以通过参数table和rowIndex来确认点击的具体是那个table和哪一行,进行传值和处理我们的逻辑。            

目录
相关文章
|
数据安全/隐私保护
苹果提交版本后显示”缺少出口合规证明“的解决办法
苹果提交版本后显示”缺少出口合规证明“的解决办法
1885 0
|
4天前
|
云安全 监控 安全
|
1天前
|
存储 机器学习/深度学习 人工智能
打破硬件壁垒!煎饺App:强悍AI语音工具,为何是豆包AI手机平替?
直接上干货!3000 字以上长文,细节拉满,把核心功能、使用技巧和实测结论全给大家摆明白,读完你就知道这款 “安卓机通用 AI 语音工具"——煎饺App它为何能打破硬件壁垒?它接下来,咱们就深度拆解煎饺 App—— 先给大家扒清楚它的使用逻辑,附上“操作演示”和“🚀快速上手不踩坑 : 4 条核心操作干货(必看)”,跟着走零基础也能快速上手;后续再用真实实测数据,正面硬刚煎饺 App的语音助手口令效果——创建京东「牛奶自动下单神器」口令 ,从修改口令、识别准确率到场景实用性,逐一测试不掺水,最后,再和豆包 AI 手机语音助手的普通版——豆包App对比测试下,简单地谈谈煎饺App的能力边界在哪?
|
9天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1095 6
|
11天前
|
机器学习/深度学习 人工智能 数据可视化
1秒生图!6B参数如何“以小博大”生成超真实图像?
Z-Image是6B参数开源图像生成模型,仅需16GB显存即可生成媲美百亿级模型的超真实图像,支持中英双语文本渲染与智能编辑,登顶Hugging Face趋势榜,首日下载破50万。
720 42
|
14天前
|
人工智能 Java API
Java 正式进入 Agentic AI 时代:Spring AI Alibaba 1.1 发布背后的技术演进
Spring AI Alibaba 1.1 正式发布,提供极简方式构建企业级AI智能体。基于ReactAgent核心,支持多智能体协作、上下文工程与生产级管控,助力开发者快速打造可靠、可扩展的智能应用。
1154 41
|
14天前
|
人工智能 前端开发 算法
大厂CIO独家分享:AI如何重塑开发者未来十年
在 AI 时代,若你还在紧盯代码量、执着于全栈工程师的招聘,或者仅凭技术贡献率来评判价值,执着于业务提效的比例而忽略产研价值,你很可能已经被所谓的“常识”困住了脚步。
910 74
大厂CIO独家分享:AI如何重塑开发者未来十年
|
2天前
|
人工智能 安全 前端开发
AgentScope Java v1.0 发布,让 Java 开发者轻松构建企业级 Agentic 应用
AgentScope 重磅发布 Java 版本,拥抱企业开发主流技术栈。
270 10
|
1天前
|
人工智能 JSON 前端开发
为什么你的API文档总是被吐槽?用这份"契约指令"终结前后端战争
本文针对前后端协作中"文档过时、不准确"的痛点,提供了一套实战验证的AI指令。通过强制结构化输入和自检机制,让AI自动生成包含完整参数、JSON示例和多语言代码的标准API契约文档,彻底解决接口沟通难题。
167 112

热门文章

最新文章