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


摘要


本章涉及主要内容:父对象和子对象、序列帧图的使用、计时器
本章节实现内容:按钮的基础功能:移入、点击状态、自动弹起


思路分析


我们的需求:<span style="color: #ff0000">制作2个不同的按钮,鼠标移入和点击都会改变状态</span>(暂不制作点击后产生的效果)

由此我们得出以下需要解决的问题:
1.鼠标移入后按钮状态改变
2.鼠标移出后状态按钮恢复
3.鼠标按下后状态按钮改变
4.鼠标释放后状态会自动恢复
5.制作2个(N个)按钮需要写2次(N次)代码?
<span style="color: white">br
br
br</span>


实现过程


新建工程

这里直接跳过,若还不会新建工程建议先学习官方教程。(新工程采用GML方式)
<span style="color: white">br
br</span>

加载精灵

1.资源准备
  这里我们需要准备2个按钮的精灵资源,资源需要3个状态分别为:常规时的样子、鼠标移入时的样子,点击(选中)时的样子,依次以序列帧方式排列并且取名为<span style="color: #ff0000">study_button_strip3</span> 和<span style="color: #ff0000">study_button1_strip3</span>,以下是本章中使用的两个素材(右键另存为即可).


study_button1_strip3

<span style="color: white">br
br</span>
2.资源导入
  直接把[步骤1]中所准备的两个按钮资源拖入到工程内(记住:不是文件夹内,要拖入到软件已经打开的工程里。),由于我们命名是以strip3,所以GMS2软件会自动把资源切割为3等分。导入资源后把精灵名字后的_strip3都删掉,变成study_button和study_button1

  • 名词解释:stripX
  • 当图片命名以时为_stripX(X代表一个数字),GMS2软件会默认该图片为序列帧并且把软件等分成X份,以X帧的形式放入同一个精灵内。注意:只支持横向,如果是两排则不行。

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

创建对象

这里直接跳过,若还不会新建对象建议先学习官方教程。(新对象命名为obj_button_father)

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

变量申明

1.因为需要申明一些不需要重置的变量,在对象中添加事件:创建
  2.申明变量,这里我们暂时只需要用到一个判断按钮状态的变量,所以在【创建】中建立一个状态变量,如下在创建中添加:

btn_state = 0;  //按钮状态 0、正常 1、移入 2、点击(选中)

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

移入与移出


  1.因为需要判断移入和移出当前对象,所以在对象中添加两个事件:鼠标移入、鼠标移出事件。
  2.在鼠标移入对象时我们需要改变按钮的状态为移入状态,如下在【鼠标移入】中添加:

btn_state = 1;  //切换移入状态

3.在鼠标移出对象时我们需要改变按钮的状态为移出状态,如下在【鼠标移出】中添加:

btn_state = 0;  //切换移入状态

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

点击效果

1.在对象中添加事件:步。
  2.在步事件中判断鼠标点击后的状态切换(也可以不用步事件,直接用鼠标点击事件,这里为了多写一些方法就用【步】了),如下在【步】中添加:

if btn_state == 1 && mouse_check_button(mb_left)    //当鼠标移入且被点击时
{
    btn_state = 2;  //切换到点击状态
}
  • 说明:mouse_check_button();
  • 这个语句是说当鼠标在点下后只要不松开就会一直执行,若想只响应鼠标点击那一瞬间的效果的话则需要用到mouse_check_button_pressed()语句;

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

自动弹起效果

1.自动弹起这里就需要用到计时器,首先在点击改变点击状态时设置计时器(如果每一帧都设置一次计时器的倒计时的话,这计时器将永不执行,在这里使用mouse_check_button的方式就是为了一直设置计时器的方式来防止在鼠标按下时执行计时器而回到常规状态),之前步事件中的代码修改为:

if btn_state == 1 && mouse_check_button(mb_left)    //当鼠标移入且被点击时
{
    btn_state = 2;  //切换到点击状态
    alarm_set(0, 3);    //设置计时器0的计时时间为3帧
}

2.计时器倒计时设置完毕后,就需要设置响应事件了,由于之前【步】中设置的是0号计时器的倒计时所以需要添加一个【计时器0】,如图所示:


<span style="color: white">br
br</span>
  3.在【计时器0】中写的代码会在之前设置的倒计时结束时激活其中的代码,这里我们需要的是他在倒计时结束后就使按钮回复初始状态,那么就在【计时器0】事件中添加:

btn_state = 0;  //转换为常规状态

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

绘制图像

1.之前的状态已经处理完毕,现在需要根据状态来显示出不同的状态,首先创建【绘制】事件(就是绘制的第一个事件,不选后面的GUI之类)。
  2.这里有个小技巧就是,之前状态变量【state】是以0、1、2分别代替普通、移入、点击状态的,而我们的精灵的顺序正好也是0、1、2代表的普通、移入、点击状态,由此我们可以直接在【绘制】中添加如下代码:

draw_self();    //绘制图像本身
image_index = btn_state;    //根据状态绘制当前精灵的第几帧

子对象添加


以上所有基本功能已经实现,下面需要添加子对象以引用之前所有的代码
  1.新建2个对象:obj_button_child、obj_button_child1
  2.设置新对象的精灵和父对象如下图:



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

  • 说明:如此设置后所有子对象都会继承父对象的所有特点,包括事件、物理等一些你没有针对子对象专门修改过的属性。若要针对部分事件进行添加的同时引用父对象事件则需要用到event_inherited()函数来引用父对象当前事件的代码,在本章中没必要针对子对象些专门的代码,所以就不做示范了,未来肯定会使用此方法的教程。
    <span style="color: white">br
    br
    br</span>

额外思考


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

提示函数:instance_position(mouse_x, mouse_y, obj_button_father)

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

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

下一章内容:按钮的选中状态,再次点击取消状态以及相同父对象情况下多个按钮选中状态互斥

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

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

推荐阅读更多精彩内容

  • 摘要 上一章:[入门]GML常用UI之按钮的制作1 本章涉及主要内容:父对象的理解、与子对象的简单控制本章节实现内...
    丿我回来了阅读 633评论 0 0
  • 之前写过一篇浏览器事件的相关操作和事件运行的原理——JavaScript浏览器事件解析。这一篇主要写一些常用的事件...
    faremax阅读 1,601评论 0 0
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,350评论 0 17
  • 1、窗体 1、常用属性 (1)Name属性:用来获取或设置窗体的名称,在应用程序中可通过Name属性来引用窗体。 ...
    Moment__格调阅读 4,477评论 0 11
  • 文字的作用在于表达一件事情,发表自己的观点,道明自己的感情,我曾经认为文字是一种很高大上的东西,以至于把他当做是...
    绝迹偏锋阅读 219评论 0 4