Framer之事件 | 如何制作安卓点击水波纹效果?

之前的 Framer 教程都是按照个人喜好去写的,没有按照难易程度形成系列。为了让大家能更好地入门,我准备由易到难写一个系列教程,尽量保持在每周一篇的频率。

导读:事件是 Framer 中的一个重要概念,它是交互动效的触发开关。它主要包括一些手势事件(触摸、滑动、双击等),还有动画运行、状态切换、页面切换等事件。我们一般通过监听事件的发生来触发一些交互动作。

事件是什么呢?你可以想象在 Framer 中有一个小人一直在盯着屏幕,当你点击或滑动屏幕时它就会告诉 Framer,Framer 就执行你写的这个事件对应的处理代码。我们经常要使用事件监听来实现一些交互效果,最常见的就是点击图层时切换图层状态。

我们一般这样定义一个事件监听操作。

每个图层对象上面都有一个 on 函数,它表示给图层添加一个事件监听方法。后面的 Events.Click 是事件类型,这里是点击事件,还有 Events.LongPress 表示长按事件、 Events.Swipe 表示扫滑事件等,具体可以在事件文档( http://framercn.com/docs#events )中查阅。而后面紧接着是一个函数,它里面的代码就是当这个事件发生之后需要执行的操作。比如这里是输出 Clicked 和图层名称。需要注意的是,你在定义后续操作时可以使用事件监听方法提供给你的两个对象: eventlayer ,第一个是当前事件对象,里面存储的有本次事件的鼠标坐标、鼠标移动距离等,第二个是事件发生所在的对象,这里就是 layerA 这个图层。

Framer 提供的事件种类非常丰富,甚至包括两指旋转、3D touch 等,完全可以满足各种原型的交互。

接下来我将用一个完整的例子具体讲解事件该如何使用。安卓 Material Design 里面的点击水波纹效果大家一定都知道:

那么用 Framer 怎么实现这个效果呢?我们先用中文描述一下这个过程:有一个按钮,当用鼠标点击它时,以点击时的位置为圆心绘制一个很小的圆,同时将其放大并不断降低透明度直至消失。接下来我们将其翻译成 Framer 的语言。

首先绘制一个按钮图层:


通过新建图层我们就在界面上绘制出了这个按钮。需要注意的是,我们要设置它的 clip 属性为 true ,这样才能保证点击时出现的水波纹超出按钮的部分被隐藏。 Utils.labelLayer(button, 'CLICK ME') 是快速给按钮设置文字并让其在按钮正中间; button.style.fontSize = '24px' 则是通过 CSS Style 将其字号变成 24 像素; button.center( ) 则是将该图层快速居中于屏幕中央。此时在屏幕正中间就出现了这个按钮。

接下来就是给它添加一个点击事件。当鼠标点击它时,会发生以下几件事:

1、在按钮中,以鼠标点击的坐标点为圆心,画一个圆形图层(水波纹)
2、将这个圆形图层逐渐变大(scale)且逐渐隐去(opacity)
3、当这个圆形图层不透明度变成0时,移除这个图层

第一步:

当鼠标点击它时,需要在点击处画一个圆形的图层作为水波纹。通过新建图层对象 ripple ,并设置它的一系列属性让它表现为一个圆形。需要注意的是,它的宽高( 这里是 240px )要比按钮大,然后我们再设置它的 scale 属性为 0.05 ,即缩小至原大小的5%,这样它刚出现时就是一个小圆点。为什么要先设置很大的宽高再通过 scale 让它显示很小,而不是设置很小的宽高点击时增大 scale 让它荡漾开呢?是因为第二种方式会导致放大后边缘模糊且有毛边。

因为是以点击处的坐标为圆心,我们不能直接写它的 x 、 y 坐标值,因为这个坐标值以它的左上角为准的。这里我们使用 midXmidY ,即其中心坐标值来表示。它的中心坐标值是动态的,即鼠标点击处的坐标值。这个事件监听方法所提供的 event 对象里面包含了鼠标坐标值,即 event.point 。但是我们不能直接使用它,因为这个坐标值是相对于 Framer 中的设备屏幕的。所以我们使用 Screen 对象的 convertPointToLayer 方法把它转换为相对于 button 图层的坐标。

然后通过 buttonaddChild 方法让这个圆形波纹变成它的子图层。

第二步:

给圆形波纹图层添加状态 bigger ,并让它通过动画切换到新状态。如下面的代码所示,在新状态 bigger 中它的 scale 变成 4 同时 opacity 变成 0 ,动画时间是 6 秒。最后通过 animate 方法执行状态切换动画。

第三步:

圆形波纹的状态切换也是一个事件,我们可以通过 onStateDidSwitch (这是一种事件简写形式,具体请看参考文档)来监听它在何时“切换完毕”,当切换完毕时将该圆形波纹删除。

其实不删除也可以,反正每个圆形波纹最终不透明度都变成 0 了,看不见了。但是点一次生成一个子图层,点击很多次就会生成很多子图层,会影响性能。关键是我是强迫症,不能忍。

这样我们就完成了安卓点击水波纹效果,总结一下事件的要点:

1、事件一般是发生在图层上的,包括手势、动画、状态切换事件等。
2、Framer 的事件方法一般会提供 layer 和 event 两个对象供你使用,可以通过它们获取事件发生的图层以及鼠标位置等。
3、Framer 提供的事件非常详细丰富,大大减少了设计师的设计难度。

点击此处,获取示例的源文件。

如需转载请注明:
** 来自 leadream 的简书 **

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

推荐阅读更多精彩内容