使用ivx制作模拟时钟的经验总结

本文分享了如何使用ivx制作模拟时钟,包括设置表盘、添加指针以及设定轨迹的过程。通过调整椭圆组件和矩形指针的坐标原点,以及在时间轴上设置旋转轨迹,实现时针、分针和秒针的转动。总结提到,为达到真实时钟效果,时间轴的原始时长应至少为实际时长的0.5%。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

之前的帖子里已经使用时间轴和轨迹实现了很多的效果,今天我们来做一个模拟时钟。主要思路是用一个作为表盘,三个矩形分别作为时针,分针和秒针,通过各自轨迹设置他们在同一时间轴下的转动圈数成一定比例关系。

1.表盘
首先是添加椭圆组件,这里我们需要设置它的原点横纵坐标都是50%,这样椭圆组件的XY坐标就是它的中心店坐标,这个XY坐标在我们设置指针的时候也要用到。
在这里插入图片描述
2.添加指针
指针使用矩形来展示的,由于指针要绕着表盘的中心点旋转,所以我们要将矩形的坐标原点与椭圆的坐标原点设置在同一个位置。因此先设置矩形的原点横坐标是50%,原点纵坐标是100%,即矩形下边界中间的位置,然后设置矩形的坐标与椭圆组件一样(50,50)。分针和秒针也是同理,只不过矩形的形状和颜色有所变动。
在这里插入图片描述
3.轨迹
最后就是轨迹的设置了,我们在时间轴里统一管理时针,分针和秒针的轨迹。这一步其实更多的是数值上的计算,以时针转一整圈360°为基准,则给时针的轨迹添加两个关键帧,0s时时针处于初始状态,在时间轴末尾的10s时表示时针的矩形的旋转角度是360°。分针和秒针的轨迹也是同理添加两个关键帧,而时针旋转360°的过程中一共历时12小时,一小时分针旋转360°,所以分针总共旋转4320°,而12小时也就是720分钟,一分钟秒针旋转360°,则秒针共旋转259200°。
在这里插入图片描述

### 使用方法 在 ivx 中实现单选功能,通常有以下几种方式: 1. **下拉菜单组件**:可以通过添加一个下拉菜单组件来实现单选功能。该组件位于拓展组件的交互与表单类中。添加后,在选项列表中输入选项并用英文逗号隔开(数据绑定的话可以绑定一个一维数组)。或者选中下拉菜单,打开自定义选项,再点击拓展组件添加下拉菜单选项,定义好每个下拉菜单选项的内容。最后给下拉菜单添加事件,当我们选择一个选项后下拉菜单会返回给我们一个参数就是它当前的选中值[^3]。 2. **手机单项选择器组件**:使用手机单项选择器组件也可以实现单选功能。手机单项选择器也是拓展组件的一种,位于拓展组件中选择器类。跟下拉菜单类似,可以在选项列表输入选项并用逗号隔开,或者数据绑定一个一维数组。需要注意的是本身单项选择器是不显示的,其初始状态为隐藏。这里需要给文本组件添加了一个事件,点击文本组件使选择器显示。当选择器选中一个选项时,单项选择器会返回一个参数——当前选中值,就可以将该值赋给设定好的变量[^3]。 3. **循环创建**:使用循环创建需要数组来作为数据来源,先将数据写入一维数组之中,然后进行数据绑定。这样就可以把选项都创建出来。接下来给 for 容器下的文本组件添加一个事件,当点击文本的时候将当前文本的数据赋值给设定好的一个文本变量——“选中的内容”。这样每一时刻循环创建下的选项都只有一个选项和“选中的内容”是相同的。最后通过三元表达式来区分选中选项的显示效果。 ### 实现方式 #### 下拉菜单组件 ```python # 示例伪代码 def add_dropdown_menu(options): # 添加下拉菜单组件 dropdown = DropdownComponent() dropdown.set_options(options) dropdown.add_event_listener('change', lambda event: print(event.selected_value)) return dropdown ``` #### 手机单项选择器组件 ```python # 示例伪代码 def add_mobile_radio_selector(options): # 添加手机单项选择器组件 selector = MobileRadioSelector() selector.set_options(options) selector.add_event_listener('show', lambda event: print("Selector shown")) selector.add_event_listener('select', lambda event: print(event.selected_value)) return selector ``` #### 循环创建 ```python # 示例伪代码 def create_options_with_loop(data_array): # 创建循环容器 loop_container = LoopContainer() loop_container.bind_data(data_array) # 为每个选项添加点击事件 for item in loop_container.items: item.add_event_listener('click', lambda event: set_selected_content(event.item_data)) # 使用三元表达式设置选中样式 def set_selected_style(item_data, selected_content): return '#5FA2DD' if item_data == selected_content else 'transparent' return loop_container ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值