• QQ21031394

    工作时间

    周一至周五:9:30-18:30

    周末及节日:根据情况调休

  • 手机版二维码

    随时手机查素材

  • 扫描二维码

    加入官方QQ群

站长推荐
提百万 联盟管理员
  • 未知地域
  • 内测小天使

    内测期间为论坛做出突出贡献的会员
  • 优秀学员勋章

    通过近期表现由站长颁发
  • 优秀新人勋章

    通过近期表现由站长颁发
  • 高级学员勋章

    通过近期表现由站长颁发
  • 特级学员勋章

    通过近期表现由站长颁发
  • 天工合约会员

    拥有浏览和下载天工精品模型区权限
  • 3647发帖数
  • 1970主题数
  • 0关注数
  • 158粉丝

[UI界面引导] UI编辑器案例:自动切换的广告位

[复制链接]
提百万 发表于 2020-11-18 01:46:20 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题 <
提莫作坊QQ群:提莫作坊www.tbwlm.cn

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
需求分析
今天,我要做一个能自动切换的广告位,先分析需求:

效果展示


模块制作
拼界面
首先是拼界面
这个界面比较简单,一个界面就可以搞定,这个界面包括了:背景、关闭按钮、图片显示区域(重点区域,后面详细讲)、调试文本、5个小点标志广告位置
如图:
其中比较复杂的是广告图片显示区域,首先,我放置了一个层(layer_img)用来响应点击、拖拽这些操作,然后给这个层里放置了一个列表img_list,用这个水平滚动列表来模拟图片拖拽的效果。
那么img_list这个列表中包含的列表项是什么呢?三张图,中间的(img)、前一张(img_1)、后一张(img_2),我只要用触发器把这三张图管理显示好,就能在拖拽时模拟出带着前一张、后一张图拖拽的效果了。
界面比较简单,拼到这里就结束了。下面开始写逻辑。
滑动切换图片
分析了需求后,我决定先实现最主要的功能:滑动切换图片。
为了滑动图片,我首先要知道的是手指是在向左滑(后一页),还是向右滑(前一页)?
为了知道手指的动作,我要知道手指按下和手指松开的坐标,就像这样,在layer_img这个控件上注册事件
点击开始,这个触发器的动作很简单,就是把全局变量“开始点”设置成触发界面坐标。
点击结束这个触发器稍微麻烦一点,把全局变量“结束点”设置成触发界面坐标后,
运算结束点和开始点的差值,然后看差值的横坐标(因为这里只能横向滑动,我并不关心手指的纵向移动)
如果横坐标差值在300以上,我认为手指已经移动的够远了,应该响应图片变化,因此这里做数值判断,然后,根据是+300,还是-300去分别调用“向前一页”或“向后一页”的触发器。
这里为什么不直接写逻辑,而要调用另一个触发器呢?把功能尽可能的分拆开,方便后面的复用,比如说,定时器到期的自动滚动,完全就可以复用“向后一页”这个触发器。

向前一页/向后一页
这两个触发器的功能是类似的,就是把全局变量“当前位置”记录的整数-1或+1.
界面刚显示的时候,当前位置显然是1.如果向前一页,我就把当前位置-1.
然而,当当前位置为0时,我并不想拖动不了,我想要显示的就是最后一张图(比如说,一共有5张图,那就显示第5张图),
那么就需要做一下修正,当当前位置<1时,就让当前位置=当前位置+图片总数
同理,当当前位置>图片总数时, 当前位置= 当前位置-图片总数
这样,我们的广告图就可以首尾连接无限循环了。
这两个触发器的作用就是用来改“当前位置”这个全局变量,改好之后,直接运行触发器“显示图片”

触发器“显示图片”
显示图片要把图片正确的显示出来,包括当前图片、上一张、下一张图片。
那么首先,我们应该有一个图片数组,这个图片数组在游戏开始时我去定义了。例如广告图片组[1]=图片1……依次类推
所以知道“当前位置”,就能计算出当前图片、上一张、下一张图片分别是广告图片组中的哪一张。
然后用这个动作将图片显示出来:
这个动作我使用的时候绕了好久才想清楚,因为很难理解列表和列表项之间的关系。如下图,是一个错误的写法,错在哪?你发现了吗?

答案揭晓,因为我们只能对“列表项”的子控件改图片,不能对“列表”的子控件改图片。因为程序不知道你要对列表中的哪个列表项的子控件改图片。
列表和列表项
好吧让我来解释一下。
这是列表
这是列表项
你要告诉Uni你要改变哪只象的图片(误),Uni才能改,你直接丢个列表那程序是不能理解的。
那么如何获得这只象呢?用这个参数“获取列表项”


之所以我这里做了这么多图……是因为真的很难找,我相信你(我)看(做)完这些图后,一定能区分出表和象了吧?
好的,做到这里,最主要的功能,“滑动切换图片”就完成了。

定时切换
游戏开始后,创建一个一次性的计时器“自动后滚计时器”,到时间后去触发触发器“向后一页”
这个计时器赋值给全局变量“timer”
一旦切换了图片(运行了触发器“显示图片”),就删除掉timer计时器,然后重新创建一个计时器。
由于前面的触发器功能区分比较好,加这个定时切换只要简单的一个触发器,并且在“显示图片”触发器后面加2句:删除timer,运行“自动后滚计时器”

其余功能比较简单,不再累述。

免责条款:本站仅提供学习的平台,所有资料均来自于网络,版权归原创者所有!本站不提供任何保证,并不承担任何法律责任,如果对您的版权或者利益造成损害,请提供相应的资质证明,我们将于3个工作日内予以删除。

本网站所收集的部分公开资料来源于互联网,转载的目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。本站部分作品是由网友自主投稿和发布、编辑整理上传,对此类作品本站仅提供交流平台,不为其版权负责。如果您发现网站上有侵犯您的知识产权的作品,请与我们取得联系,我们会及时修改或删除。

本网站所提供的信息,只供参考之用。本网站不保证信息的准确性、有效性、及时性和完整性。本网站及其雇员一概毋须以任何方式就任何信息传递或传送的失误、不准确或错误,对用户或任何其他人士负任何直接或间接责任。在法律允许的范围内,本网站在此声明,不承担用户或任何人士就使用或未能使用本网站所提供的信息或任何链接所引致的任何直接、间接、附带、从属、特殊、惩罚性或惩戒性的损害赔偿。

精彩评论1

袋鼠宝宝 发表于 2022-5-22 01:55:32 | 显示全部楼层 <
我来打个酱油吧,这个帖子的内容我没接触过也暂时不会去研究这一块

强调下版规的规定,如有恶意灌水从重处罚:
=====发表主题规则=======
1.主题内容请一定要附带预览图片,谢谢;
2.搬运来的东西请尽量不要卖钱!;
3.发帖有任何疑问请联系QQ21031394;
=====发表回复规则=======
1.禁止直接复制标题内容的;
2.禁止纯数字或者纯字母的;
3.禁止乱打一通文不对题;
4.禁止屠版和刷分行为;
第一次扣分处理,第二次扣分+警告,警告三次禁言三天,绝不手软,情况严重的直接封号,请大家珍惜自己的账号!

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

猜你喜欢
天工维度唯一QQ群
786014245

欢迎进群交流,入群答案:编辑器

  • 官方在线客服

    QQ客服:小雪

    点击交谈

    QQ客服:砂糖

    点击交谈

    团队老大:荀公子

    商务合作
  • 上海市静安区共和新路4718号宏慧新汇园6号楼603室

  • 手机扫码查看手机版

    手机查找资源更方便

  • 扫一扫关注官方微信

    加入官方QQ群

Powered by 天天RPG&DZX3.4 ©2020-2021 Comsenz Inc.提百万设计( 沪ICP备18032615号-1 )营业执照