[入门]GML常用UI之按钮的制作2


摘要


上一章:[入门]GML常用UI之按钮的制作1

本章涉及主要内容:父对象的理解、与子对象的简单控制
本章节实现内容:在前章内容之下,实现按钮的按下与手动控制弹起,同时实现所有归属父对象的子对象的按下状态是互斥的(此功能可以制作选择中框等)
<span style="color: white">br
br
br</span>


上章解答


题目:现在情况是会自动弹起,但是当鼠标在按钮上的时候自动弹起也会回归到常规状态(正确的应该是移入状态),有没有一个方法在鼠标在按钮上时按钮自动弹起的时候它是处于移入状态

思路:检测鼠标当前所在的按钮实例,让鼠标所放置的实例的状态恢复成移入状态而不是普通状态

如此我们需要在自动恢复状态的地方加入判断鼠标当前所在的按钮,【计时器0】内的代码修改为如下:

var button = instance_position(mouse_x, mouse_y, obj_button_father) //判断并获取鼠标所在实例位置
if button > 0   btn_state = 1;  //如果是当前实例则切换成移入状态
else    btn_state = 0;  //如果不是当前实例则切换成普通状态

以上就能正确识别鼠标所处在具体哪个按钮之上,下面开始正式教程
<span style="color: white">br
br
br</span>


思路分析


需求是:同一个父对象中,2个子对象按钮,1个自动弹起,另外个需要手动点击才会弹起,同时相同子对象不同实例之间只有1个会被同时按下。

由此我们需要解决以下问题:
1.如何判断是否需要自动弹起
2.手动弹起的按钮的状态判断
3.相同子对象不同实例间按下状态的互斥。
<span style="color: white">br
br
br</span>


实现过程


  • 前提概要:父对象与子对象之间的关系上一章已经说过,本章会有一些简单的子对象引用和变量修改。
    <span style="color: white">br
    br</span>

不自动弹起

1.新增字段
  咱们这里既需要保留自动弹起功能,又需要一个可持续选中的按钮的话就需要针对不同的按钮功能类型进行识别,咱们在父对象obj_button_father创建事件中新增一个变量来进行区分:

btn_type = 0;   //按钮类型 0、点击后选中 1、点击会自动弹起

<span style="color: white">br
br</span>

2.步事件区分判断
  已经创建好的按钮类型,需要在步事件内进行区分判断后才能用进行下一步的功能实现,如此obj_button_father事件中进行一些改写,代码如下:

switch btn_type
{
    case 0://以下是点击后变为选中,再次点击弹起(点击其他实例也会弹起)
        break;
        
    case 1://以下是点击会自动弹起
        if btn_state == 1 && mouse_check_button(mb_left)    //当鼠标移入且被点击时
        {
            btn_state = 2;  //切换到点击状态
            alarm_set(0, 3);    //设置计时器计时为3帧
        }
        break;
}

以上,case 0既是我们即将增加按下的代码
<span style="color: white">br
br</span>
3.按下的处理
  按下的逻辑和之前几乎相同,唯一不同的就是咱们这里不需要让他自动弹起,那么就不需要在case 0的按下逻辑中添加计时器(上一章:计时器0的作用就是控制按钮的自动弹起),case 0中新增代码如下:

case 0://以下是点击后变为选中,再次点击弹起(点击其他实例也会弹起)
    if btn_state == 1 && mouse_check_button(mb_left)//当鼠标移入且被点击时
    {
    btn_state = 2;//切换到点击状态
    }
    break;

<span style="color: white">br
br</span>
4.再次点击弹起
  再次点击弹起的前提必须是当前按钮处于被按下的情况下,那么只需要鼠标点击时判断按钮是否被按下即可,同时需要注意的是为了避免多次触发按下和取消按下状态,这里移入和被点击对于每一次点击都只需要触发一次,而不需要多次触发了。所以mouse_check_button需要改成mouse_check_button_pressed(这两个接口的区别上一章已经说明),代码修改如下:

case 0://以下是点击后变为选中,再次点击弹起(点击其他实例也会弹起)
    if btn_state == 1 && mouse_check_button_pressed(mb_left)//当鼠标移入且被点击时
    {
        btn_state = 2;//切换到点击状态
    }
    else if btn_state == 2 && mouse_check_button_pressed(mb_left)//当按钮状态被按下且被点击时
    {
        btn_state = 0;
    }
    break;
  • 说明:以上其实已经实现了相同子对象不同实例之间只有1个会被同时按下,因为在执行按下【按钮1】的时候,如果【按钮2】是处于按下状态的话,也会执行else if里面的逻辑,简意就是,每次点击其实会对所有当前父对象的子对象都单独执行一次独立的代码逻辑。

<span style="color: white">br
br</span>
5.子对象的引用修改
  按理来说,功能已经基本完成,但是现在遇到一个问题:现在不管刷多少个子对象他都是需要手动点击才会弹起的,那么我们需要obj_button_child在点击后才会弹起且obj_button_child1在点击后3帧会自动弹起就需要做区分了。
  上面我们是通过字段btn_type来进行识别的,那么只需要在子对象中对btn_type来进行修改则可,因为btn_type在父对象中默认是0,那么obj_button_child则不需要有任何修改,剩下就需要在obj_button_child1中进行修改了。
  首先在obj_button_child1中新建【创建】事件,在这里其实可以直接把父对象的创建事件复制下来填进去修改,但是若未来父对象有修改时,这里也会跟着修改会很麻烦,由此我们在这里需要引用父对象【创建】的代码后进行修改btn_type的值,代码如下:

event_inherited();//引用父对象相同事件内的代码
btn_type = 1;//修改按钮类型

如此,就可非常简单的把obj_button_child1的所有刷出来的实例改为自动弹起的。
<span style="color: white">br
br</span>
6.点击区域的识别
  基本功能已经搞定,可是在测试的时候发现一个问题:点击按钮没什么问题,但是当有按钮按下时,点击空白区域也会把按钮给弹起来。
  这问题产生的原因是由于mouse_check_button_pressedmouse_check_button都是全局响应导致的,那么我们在响应弹起逻辑时除了按钮要处于按下状态外还需要判断鼠标必须在按钮上点击才行,由此在父对象的【步】事件中做出了如下修改:

case 0://以下是点击后变为选中,再次点击弹起(点击其他实例也会弹起)
    var button = instance_position(mouse_x, mouse_y, obj_button_father) //判断并获取鼠标所在实例位置

    if btn_state == 1 && mouse_check_button_pressed(mb_left)//当鼠标移入且被点击时
    {
        btn_state = 2;//切换到点击状态
    }
    else if btn_state == 2 && mouse_check_button_pressed(mb_left)&& button > 0//当按钮状态被按下且被点击时
    {
        btn_state = 0;//切换到普通状态
    }
    break;

<span style="color: white">br
br</span>
7.弹起后的状态优化
  和上一章一样,咱们在点击弹起之后按钮是恢复为普通状态的,在这里需要用类似的方法来处理为,弹起后为鼠标移入状态,由此父对象的【步】中的最终代码如下:

switch btn_type
{
    case 0://以下是点击后变为选中,再次点击弹起(点击其他实例也会弹起)
        var button = instance_position(mouse_x, mouse_y, obj_button_father) //判断并获取鼠标所在实例位置

        if btn_state == 1 && mouse_check_button_pressed(mb_left)//当鼠标移入且被点击时
        {
            btn_state = 2;//切换到点击状态
        }
        else if btn_state == 2 && mouse_check_button_pressed(mb_left)&& button > 0//当按钮状态被按下且被点击时
        {
            btn_state = 0;//切换到普通状态
            if button.btn_state == 0 button.btn_state = 1;//切换到移入状态
        }
        break;
        
    case 1://以下是点击会自动弹起
        if btn_state == 1 && mouse_check_button(mb_left)    //当鼠标移入且被点击时
        {
            btn_state = 2;  //切换到点击状态
            alarm_set(0, 3);    //设置计时器计时为3帧
        }
        break;
}

<span style="color: white">br
br
br</span>


额外思考


现在功能已经没什么大问题了,但是出现另外个问题就是当点击obj_button_child1时obj_button_child被按下的按钮也会弹起来,这明显不是我们想要的,那么应该怎么解决它呢?

提示:针对按钮进行分组,并且在点击的时候进行判断

<span style="color: white">br
br
br</span>

本次教程到此结束,有任何疑问和意见可以留言或者Q群询问

下一章内容:点击按钮后弹出界面

<span style="color: white">br
br</span>
教程中源文件 本次教程暂不提供源文件等本系列课程结束后统一提供下载
提取密码:

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容

  • 摘要 本章涉及主要内容:父对象和子对象、序列帧图的使用、计时器本章节实现内容:按钮的基础功能:移入、点击状态、自动...
    丿我回来了阅读 672评论 0 0
  • 1、窗体 1、常用属性 (1)Name属性:用来获取或设置窗体的名称,在应用程序中可通过Name属性来引用窗体。 ...
    Moment__格调阅读 4,534评论 0 11
  • 一、简介 <<UIButton(按钮) : 既能显示文字,又能显示图片,还能随时调整内部图片和文字的位置,实现了监...
    无邪8阅读 5,647评论 0 2
  • style 修饰width 宽度height 高度title 想说明的text-align 水平对齐...
    蒲公英_前端开发者阅读 9,204评论 4 58
  • 文件下载时,中文名乱码处理 //文件名中文乱码fileName = new String(fileName.get...
    徐俊阅读 150评论 0 1