- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我想构建一个简单的自定义 View ,它使用 UIDynamicAnimator 从底部向上滑动。
当应用程序加载时,我使用以下方法从屏幕偏移 View :
panelWidth = originView!.frame.size.width
panelHeight = originView!.frame.size.height/2
screenHeight = originView!.frame.size.height
// Set the frame for the container of this view based on the parent
container.frame = CGRectMake(0, screenHeight, panelWidth, panelHeight)
为了设想这一点,我希望 View 显示为:
|-----|
| |
| A | <--- Main View
| |
|-----|
|-----|
| B | <--- Second View (offset by screen height so it draws directly under (0,height))
|-----|
我已经设置了手势识别器来检测我何时向上和向下滑动(向上滑动显示,向下滑动关闭),但是现在 View 从屏幕上弹开,我似乎永远无法恢复。
对于我的动画师,我使用以下代码
animator.removeAllBehaviors()
isOpen = open
let gravityY:CGFloat = (open) ? -0.5 : 0.5
let gravityX:CGFloat = 0
let magnitude:CGFloat = (open) ? -20 : 20
let boundaryY:CGFloat = (open) ? -panelHeight : panelHeight
let boundaryX:CGFloat = (open) ? 0 : 0
在展示其余代码之前,我想我应该先讨论一下常量。矢量数学不是我的强项,所以这可能是所有这些都出错的唯一原因。当 open
为真时,我将值设置为负值,因为我想将 View 动画化回屏幕,这意味着它向上动画化,因此我假设我需要负重力。
我将 boundaryY 设置为面板的高度,因为我只想将它动画到屏幕上到窗口的高度,目前它飞离顶部(当我调试 screen height = 667 和 panelHeight = 333.5 所以我不明白为什么它超过了那个标记)
// animator behaviours - here I just create animaters on the panels container
let gravityBehaviour:UIGravityBehavior = UIGravityBehavior(items: [container])
let collisionBehaviour:UICollisionBehavior = UICollisionBehavior(items: [container])
let pushBehaviour:UIPushBehavior = UIPushBehavior(items: [container], mode: UIPushBehaviorMode.Instantaneous)
let panelBehaviour:UIDynamicItemBehavior = UIDynamicItemBehavior(items:[container])
// Gravity behaviour - I don't want it to move in X direction, only Y
gravityBehaviour.gravityDirection = CGVectorMake(gravityX, gravityY)
// collision detection - I think this is the major problem, how does this work...
collisionBehaviour.addBoundaryWithIdentifier("basePanelBoundary", fromPoint: CGPointMake(boundaryX, 0), toPoint: CGPointMake(boundaryX, boundaryY))
// push behaviours
pushBehaviour.magnitude = magnitude
// panel behaviours
panelBehaviour.elasticity = 0.3
// bind behaviours
animator.addBehavior(gravityBehaviour)
animator.addBehavior(collisionBehaviour)
animator.addBehavior(pushBehaviour)
animator.addBehavior(panelBehaviour)
我主要关心碰撞检测,因为我认为这是导致 View 旋转和飞离屏幕的原因,我该如何解决这个问题?
最佳答案
经过一些进一步的研究,我意识到我使用了太多的组件来实现我想要的动画,我也意识到我的边界定义不当,这就是导致我的面板从窗口弹出的原因。
为了解决这个问题,我首先修改了我的边界,以便它们与我在屏幕上指定的坐标共存:
collisionBehavior.addBoundaryWithIdentifier("upperBoundary", fromPoint: CGPointMake(0, screenHeight - panelHeight), toPoint: CGPointMake(boundaryX, screenHeight - panelHeight))
collisionBehavior.addBoundaryWithIdentifier("lowerBoundary", fromPoint: CGPointMake(0, screenHeight+panelHeight), toPoint: CGPointMake(boundaryX, screenHeight+panelHeight))
然后我定义了一个重力向量,它的值受到 open
bool 切换值的影响:
let gravityY:CGFloat = (open) ? -1.5 : 1.5
gravityBehavior.gravityDirection = CGVectorMake(0, gravityY)
最后,我将行为绑定(bind)到动画师,动画按预期工作。
总而言之,如果您是 UIDynamics 的新手,我建议您先花一些时间在纸上,然后再深入研究并亲自动手编写代码,一旦我分解了这个问题,它就比我第一次尝试容易得多。
工作代码
func showBasePanel(open:Bool)
{
animator.removeAllBehaviors()
isOpen = open
// Define constants to be plugged into animator
let gravityY:CGFloat = (open) ? -1.5 : 1.5
let boundaryY:CGFloat = panelHeight
let boundaryX:CGFloat = panelWidth
// animator behaviours
let gravityBehavior:UIGravityBehavior = UIGravityBehavior(items: [container])
let collisionBehavior:UICollisionBehavior = UICollisionBehavior(items:[container])
let panelBehavior:UIDynamicItemBehavior = UIDynamicItemBehavior(items:[container])
// Set the behvaiours
panelBehavior.allowsRotation = false
panelBehavior.elasticity = 0
// Set collision behaviours
collisionBehavior.addBoundaryWithIdentifier("upperBoundary", fromPoint: CGPointMake(0, screenHeight - panelHeight), toPoint: CGPointMake(boundaryX, screenHeight - panelHeight))
collisionBehavior.addBoundaryWithIdentifier("lowerBoundary", fromPoint: CGPointMake(0, screenHeight+panelHeight), toPoint: CGPointMake(boundaryX, screenHeight+panelHeight))
gravityBehavior.gravityDirection = CGVectorMake(0, gravityY)
// set the animator behvaiours
animator.addBehavior(gravityBehavior)
animator.addBehavior(panelBehavior)
animator.addBehavior(collisionBehavior)
}
关于ios - Swiftui 动态动画面板从下到上,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29659360/
我有一个 Bootstrap 面板,里面有另一个面板。两者在面板标题中都有一个字形图标。默认情况下,面板是折叠的。当面板折叠时,将设置 glyphicon-unchecked。当我点击这个字形图标时,
使用 Grafana 时,我们会在某些电视上使用它。有谁知道制作它的方法,如果有人添加面板,更改布局等,它不仅会自动刷新数据,还会自动刷新实际仪表板? 我们真的厌倦了不断要求具有远程访问权限的人登录并
基本上,我试图让屏幕底部有 3 个按钮,然后在屏幕中间有一个包含文字的标签。但是,我似乎无法同时在 GUI 中同时拥有按钮和标签。我是一名初学者,对布局了解不多(即使我已经阅读过它们),因此任何帮助/
作为学校的类(class)作业,我们必须提出一个自定义项目,我选择了一个原本打算在 ActionScript 上编写的游戏创意,但决定在 Java 上插入它。最初进展顺利,游戏代码正常运行, Spri
我正在尝试使用 Java Graphics 制作一个生命模拟游戏,但是当运行我的代码时,屏幕的左侧三分之一是灰色的。我希望整个屏幕是白色的,黑色方 block 代表生命方 block 。我对所有 ja
下面是动态驱动的一个不错的“下拉面板”。 http://www.dynamicdrive.com/dynamicindex17/dddropdownpanel.htm 如您所见,它是一个面板,在打开时
所以我有这个函数 onDisplayError ,如果请求失败,每次都会调用它。这意味着如果用户按下保存按钮并且 3 个请求失败,我当前会收到 3 个弹出消息。我的目标是此函数检查我的弹出窗口是否已打
我正在尝试为我的一个类(class)制作一款游戏,但在实现一些我想做的事情时遇到了麻烦。本质上,我希望在同一个图形用户界面窗口中包含多个不同的部分。 据我了解,我会使用 JPanel 来创建这些不同的
我目前正在测试这种类型的面板 jquery: http://codyhouse.co/gem/css-slide-in-panel/ 但是当我想检测从顶部滚动以显示一个 div 时:没办法:( 一种检
我可能正在搜索错误的问题,但我找不到这个问题的答案。 我有一个 AutoScroll 设置为 true 的面板。控件动态添加到面板。我需要在滚动条可见时触发一个事件,但我找不到这样的事件。 如有任何建
我有一堆 Bootstrap 面板,其中一些是相互关联的。有点像 Panel A -> Panel B -> Panel C 当用户单击面板 B 时,将显示面板 C,当单击面板 C 时,将显示面板 D
我正在尝试开发一种带有指标的下拉列表,并相应地针对应该出现在仪表板上的选定指标特定面板。反之亦然,如果未选择指标,则面板应隐藏。 我找到了链接 http://search-devops.com/m/k
我有一个窗口,窗口里面有面板。我动态地向面板添加组件。这些组件采用“hbox”布局,以便它们水平排列。单击按钮后,我将在“hbox”布局中再向面板添加一行类似组件。这里的问题是我想在第一行下面添加第二
我使用 jQuery Accordion 将表单拆分为多个面板,并使用 jQuery 验证来检查所需字段。只要验证字段位于打开的面板中,它就可以很好地显示已验证字段中的错误。 举个例子。假设我有三个
我正在尝试检查我的面板是打开还是关闭。 我尝试过这样的: $(document).on('open', '.ui-panel', function(){ console.log('open');
我有一个面板,我想将其 float 在所有窗口之上并出现在所有空间中。这可以通过 轻松完成 [self.panel setLevel:kCGUtilityWindowLevel]; [self.win
我想在格子中的单个面板上叠加多个组,并且想要独立的回归线。 获得多个面板相当容易,每个面板都有一条使用条件因子的回归线: xyplot( Petal.Width ~ Petal.Length |
Delphi 有滑动(动画)面板组件吗? 例如可以在 Raize Components 中找到它(带有“热点”或隐藏/显示按钮的左侧面板)。 我不需要一个可调整大小的面板,而是一个可以从左向右水平平滑
我有一个 Bootstrap Accordion : 我想禁用非事件面板中的所有输入控件。仅验证事件面板。 我有一个检测事件选项卡的功能: $(".panel").on("show.bs.collap
我正在尝试将组件放入不同尺寸的面板中。但是,我意识到 GridLayout 将大小相同的部分分开。如何实现如下图所示 enter image description here import java.
我是一名优秀的程序员,十分优秀!