Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
柿饼_PersimmonUI
【PersimmonUI柿饼学习营】+ A Byte of China + 平板界面
发布于 2018-09-09 03:13:44 浏览:3789
订阅该版
* 本帖最后由 ianhom 于 2018-9-11 13:39 编辑 * 第三周作业:制作平板效果 **_开发环境_** RTT + PerimmonUI + 野火RT1052Mini + 5寸800*480触屏 ![wx_camera_1535343243074.jpg](/uploads/201809/09/024423y42q4jqohzxmh780.jpg) **_开发过程_** 本周进一步学习了PersimmonUI柿饼的控件功能,配合丰富的API,JavaScript可以方便灵活实现酷炫的效果。作业的重点:**滑动解锁,应用集成,使用新应用尝试新的API、下拉动画效果**。 滑动解锁:使用slider控件,范围拉的足够大,隐藏图片即可,滑屏成功后将数字键盘显示出来,输入密码(6666),若不正确可重新输入,若正确在进入主页面。 ![TIM截图20180909025752.png](/uploads/201809/09/030612gqge44g49snk40kq.png) ![TIM截图20180909025852.png](/uploads/201809/09/030613ia56yysa6ae0hsww.png) ![TIM截图20180909025955.png](/uploads/201809/09/030614h26v1zjs6x1szzvu.png) ![TIM截图20180909030035.png](/uploads/201809/09/030614imnm4136gi00hgch.png) 应用集成:在前两周的学习中,已经完成了RT-Thread广告,计算器和2048,这里需要将这些应用集成到主页中。主页中需要增加ListCtrl作为一个大容器,实现滑动选择。然后在ListCtrl中增加若干个Panel作为小容器,在Panel中存放button和label即可,我们可以通过button来切换不同的page(即应用)。还要在每个应用中增加一个back键以便回到主页面。 ![TIM截图20180909030230.png](/uploads/201809/09/030615b4j2zoxhvl8lnzoz.png) ![TIM截图20180909030344.png](/uploads/201809/09/030615gbtphexwbe4b4x5b.png) 新API:最关键的是时间API,在这次作业中新增了一个小游戏,如果选择了No,则这个No的button会跑到一个随机位置,就是傲娇地不让点,如果点击的是YES,等5秒后可以退回到主页面,这个page中没有设置back键,只能等时间到后退出。 ![TIM截图20180909030555.png](/uploads/201809/09/030615gr7py4k446w7plyj.png) 详情请参考源码 ```var t = 5; var page = { data : {timer1 : 0, timer2 : 0}, onYes : function(e) { var thiz = this; this.setData({label2 : {position : {x:268,y:79},refresh:true}}) this.setData({page3: {refresh:true}}) this.data.timer1 = setTimeout(function() { console.log('timer1 timeout'); clearInterval(thiz.data.timer2); clearTimeout(thiz.data.timer1); pm.navigateBack(); }, 1000 * 5); this.data.timer2 = setInterval(function() { console.log(t) t -= 1; }, 1000); }, onNo : function(e) { var xx = Math.floor(Math.random()*600+10) var yy = Math.floor(Math.random()*360+100) console.log(xx,yy) this.setData({button2 : {position : {x:xx,y:yy},refresh:true}}) this.setData({page3: {refresh:true}}) } }; Page(page);``` 下拉动画效果:这里我们尝试使用**timer**的API和**setData position**的方式来组合一个**下拉通知栏**,定时快速修改通知栏的页面位置,实现下拉的动画效果。 ![TIM截图20180909141751.png](/uploads/201809/09/141819cfmdtovge4yty4qu.png) ```var p = -470; var q = 0; var page = { data : {timer1 : 0, timer2 : 0}, onbutton: function(e) { var thiz = this; switch(e.target.id){ case "button1": pm.navigateBack(); break; case "button2": pm.navigateTo({url: "page4/page4"}); break; case "button3": pm.navigateTo({url: "page5/page5"}); break; case "button4": pm.navigateTo({url: "page3/page3"}); break; case "button5": pm.navigateTo({url: "page6/page6"}); break; case "button6": case "button7": case "button8": case "button9": case "button10": case "button11": pm.navigateTo({url: "page7/page7"}); break; case "button12": this.data.timer1 = setTimeout(function() { console.log('timer1 timeout'); clearInterval(thiz.data.timer2); clearTimeout(thiz.data.timer1); p = -470 }, 300 * 1); this.data.timer2 = setInterval(function() { thiz.setData({listctrl2 : {position : {x:19,y:p}}}) thiz.setData({listctrl2 : {refresh:true}}) //thiz.setData({page2: {refresh:true}}) p += 16; }, 10); this.setData({label2 : {position : {x:268,y:79},refresh:true}}) this.setData({page3: {refresh:true}}) break; case "button13": this.data.timer1 = setTimeout(function() { console.log('timer1 timeout'); clearInterval(thiz.data.timer2); clearTimeout(thiz.data.timer1); q = 0 thiz.setData({page2: {refresh:true}}) }, 300 * 1); this.data.timer2 = setInterval(function() { thiz.setData({listctrl2 : {position : {x:19,y:q}}}) thiz.setData({listctrl2 : {refresh:true}}) //thiz.setData({page2: {refresh:true}}) q -= 16; }, 10); this.setData({label2 : {position : {x:268,y:79},refresh:true}}) this.setData({page3: {refresh:true}}) break; } } }; Page(page); ``` 附件是柿饼工程,这里抛砖引玉,期待大家更完善、更有趣的版本。 **_效果展示_** 滑屏解锁,输入密码,进入应用,退出,锁屏![hw3.gif](/uploads/201809/09/024343y1btp22pbk0h2y2i.gif) 增加了一个小游戏 ![hw3-1.gif](/uploads/201809/09/024343mqzqsc7svqxq3xq3.gif) 模拟下拉通知栏 ![GIF.gif](/uploads/201809/11/133847f7tyaw70rknkeysa.gif) **_总结_** 时间匆忙,还有好多控件没有试验,不过相信后面的学习中肯定会使用到。 在设计时,要考虑清楚控件之间的堆叠关系 程序中应该还有不完善的地方,期待大佬们多多指导。 柿饼工程 ![hw3-1-10.rar](/uploads/201809/09/142244kmfp888mnzxxmumt.rar)
查看更多
9
个回答
默认排序
按发布时间排序
werrysuzhen
2018-09-10
这家伙很懒,什么也没写!
膜拜
flyboy
2018-09-11
Do my self();
强:call:
小住住
认证专家
2018-09-14
这家伙很懒,什么也没写!
这玩意这么好用,牛逼。
ianhom
2018-09-14
这家伙很懒,什么也没写!
>这玩意这么好用,牛逼。 --- 恩,确实挺方便的
ianhom
2018-09-14
这家伙很懒,什么也没写!
>膜拜 --- 是柿饼做的好,我是个搬运工
ianhom
2018-09-14
这家伙很懒,什么也没写!
>强 --- 柿饼确实很强
bernard
2018-09-14
这家伙很懒,什么也没写!
还需要更强
yuexiaoban
2018-12-17
这家伙很懒,什么也没写!
入门教程在哪里
flyboy
2018-12-19
Do my self();
>入门教程在哪里 --- 官网入门教程里就有
撰写答案
登录
注册新账号
关注者
0
被浏览
3.8k
关于作者
ianhom
这家伙很懒,什么也没写!
提问
17
回答
16
被采纳
0
关注TA
发私信
相关问题
1
【PersimmonUI柿饼学习营】+ A Byte of China + 环境搭建&20W年薪广告
2
【柿饼学习营】+werrysuzhen+20W年薪作业
3
【PersimmonUI柿饼学习营】+ meetwit + 20W年薪广告&lesson01
4
【PersimmonUI柿饼学习营】+ DaZhou + 20W年薪作业+视频有彩蛋
5
【PersimmonUI柿饼学习营】+ DMY+ lesson01 20W年薪广告
6
【PersimmonUI柿饼学习营】+ Bigmagic+20W年薪广告&day01
7
【PersimmonUI柿饼学习营】+ chowguohua+年薪广告
8
【柿饼学习营】+werrysuzhen+脚本及事件学习
9
【PersimmonUI柿饼学习营】+ DaZhou+ 手把手教你做计算器
10
【PersimmonUI柿饼学习营】+ A Byte of China + 2048游戏
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
RT-Thread项目助手v0.2.0 - 支持Env Windows
2
RttreadV5.10上,GD32F450Z RTC时间显示问题
3
rt-smart启动流程分析
4
EtherKit快速上手PROFINET
5
RTThread USB转串口无法接收数据
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
813
个答案
177
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
149
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
3
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部