首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用FramerJS对图层进行对中单击

使用FramerJS对图层进行对中单击
EN

Stack Overflow用户
提问于 2017-05-16 18:22:28
回答 2查看 159关注 0票数 0

目标是将按钮层从屏幕中间的底部垂直向上移动,同时增长到更大的尺寸。然而,在点击图层时,它不会移动到精确的中心。它向上移动,但向右移动。为什么会这样呢?

代码语言:javascript
复制
bg = new BackgroundLayer
    backgroundColor: "#f39c12"

button = new Layer
    width:  100
    height: 100
    borderRadius: 100
    backgroundColor: "white"
    x: Align.center
    y: Align.bottom(-100)

button.on Events.Click, ->
    button.states.next()

button.states = 
    StateA:
        width:  300
        height: 300
        borderRadius: 300
        y: Align.center 
EN

回答 2

Stack Overflow用户

发布于 2017-05-18 08:16:14

原因是,只有在创建层或状态时才计算Align.center。因此,将x: Align.center添加到状态也不起作用(正如您可能期望的那样)。

但是,通过将状态的midX属性设置为Screen.midX,有一种简单的方法可以做到这一点。完整的例子:

代码语言:javascript
复制
bg = new BackgroundLayer
    backgroundColor: "#f39c12"

button = new Layer
    width:  100
    height: 100
    borderRadius: 100
    backgroundColor: "white"
    x: Align.center
    y: Align.bottom(-100)

button.on Events.Click, ->
    button.states.next()

button.states = 
    StateA:
        width:  300
        height: 300
        borderRadius: 300
        y: Align.center 
        midX: Screen.midX

工作原型可以在这里找到:https://framer.cloud/RsULi

票数 1
EN

Stack Overflow用户

发布于 2017-05-17 03:01:37

当您放大按钮的高度和宽度时,按钮会放大,但是它的xy属性可能不会像您预期的那样改变。

相反,请尝试在scale中调整StateA

代码语言:javascript
复制
button.states = 
    StateA:
        borderRadius: 300
        y: Align.center
        scale: 3
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44008911

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档