- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 View 的 layer
上制作动画作为 progress bar
。我可以暂停和恢复图层动画,但无法获得暂停时完成的动画百分比。
动画 View 宽度的代码
UIView.animate(withDuration: 3, delay: 0, options: .curveLinear, animations: {
self.progressView.frame.size.width = self.view.bounds.width - 40
}, completion: nil)
用于暂停动画
func pauseLayer(layer: CALayer) {
let pausedTime: CFTimeInterval = layer.convertTime(CACurrentMediaTime(), from: nil)
layer.speed = 0.0
layer.timeOffset = pausedTime
}
要恢复的动画代码
func resumeLayer(layer: CALayer) {
let pausedTime: CFTimeInterval = layer.timeOffset
layer.speed = 1.0
layer.timeOffset = 0.0
layer.beginTime = 0.0
let timeSincePause: CFTimeInterval = layer.convertTime(CACurrentMediaTime(), from: nil) - pausedTime
layer.beginTime = timeSincePause
}
最佳答案
诀窍是检查动画层的 presentationLayer。这是您看到的动画模型,以及为什么您在评论中声明宽度从未改变。这是因为一旦添加动画,模型层值和帧就会更新,您所看到的只是 presentationLayer 有点像电影。我需要知道您正在应用哪种类型的动画的原因是这样我就可以知道我试图获得表示层的什么属性。否则,你们在关于检查 bounds.width 以确定动画进度的评论中都走在了正确的轨道上。试一试。
import UIKit
class ViewController: UIViewController {
var fakeProgress = UIView()
var progressLabel = UILabel()
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
let progressContainer = UIView(frame: CGRect(x: 20, y:50, width: self.view.bounds.width - 40, height: 40))
progressContainer.backgroundColor = UIColor.lightGray
fakeProgress = UIView(frame: CGRect(x: 0, y: 0, width: 0, height: 40))
fakeProgress.backgroundColor = .green
self.view.addSubview(progressContainer)
progressContainer.addSubview(fakeProgress)
progressLabel.frame = CGRect(x: 0, y: 0, width: 10, height: 40)
progressLabel.translatesAutoresizingMaskIntoConstraints = false
progressContainer.addSubview(progressLabel)
progressLabel.text = "0%"
progressLabel.leadingAnchor.constraint(equalTo: progressContainer.leadingAnchor, constant: 4).isActive = true
progressLabel.centerYAnchor.constraint(equalTo: progressContainer.centerYAnchor, constant: 0).isActive = true
let button = UIButton(frame: CGRect(x: 20, y: self.view.bounds.height - 60, width: self.view.bounds.width - 40, height: 40))
button.addTarget(self, action: #selector(toggleAnimation), for: .touchUpInside)
button.setTitle("press for something", for: .normal)
button.backgroundColor = UIColor.green
button.setTitleColor(UIColor.white, for: .normal)
self.view.addSubview(button)
UIView.animate(withDuration: 3, delay: 0, options: .curveLinear, animations: {
self.fakeProgress.frame.size.width = progressContainer.bounds.width
}, completion: { (finished) in
self.progressLabel.text = "\(100.0)%"
self.progressLabel.isHidden = false
})
pauseLayer(layer: fakeProgress.layer)
}
@objc func toggleAnimation(){
if let presentation = fakeProgress.layer.presentation(){
let width = presentation.bounds.width
let progress = (width/(self.view.bounds.width - 40)) * 100
print("the progress is \(progress)")
progressLabel.text = "\((ceil(progress * 100))/100)%"
}else{
let progress = (fakeProgress.frame.width/(self.view.bounds.width - 40)) * 100
if progress == 100{
print("finished")
progressLabel.text = "\(100)%"
}else{
print("not started")
progressLabel.text = "\(0)%"
}
}
if fakeProgress.layer.speed == 0{
resumeLayer(layer: fakeProgress.layer)
}else{
pauseLayer(layer: fakeProgress.layer)
}
}
func pauseLayer(layer: CALayer) {
progressLabel.isHidden = false
let pausedTime: CFTimeInterval = layer.convertTime(CACurrentMediaTime(), from: nil)
layer.speed = 0.0
layer.timeOffset = pausedTime
}
func resumeLayer(layer: CALayer) {
progressLabel.isHidden = true
let pausedTime: CFTimeInterval = layer.timeOffset
layer.speed = 1.0
layer.timeOffset = 0.0
layer.beginTime = 0.0
let timeSincePause: CFTimeInterval = layer.convertTime(CACurrentMediaTime(), from: nil) - pausedTime
layer.beginTime = timeSincePause
}
}
关于ios - 获取在 View 层上完成的动画百分比,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49915764/
从 Redis 获取消息时,onDone:(){print('done')} 从未起作用。 import 'package:dartis/dartis.dart' as redis show PubS
昨天我玩了一些vim脚本,并设法通过循环来对当前输入的内容进行状态栏预测(请参见屏幕截图(灰色+黄色栏))。 问题是,我不记得我是怎么得到的,也找不到我用于该vim魔术的代码片段(我记得它很简单):它
我尝试加载 bash_completion在我的 bash (3.2.25) 中,它不起作用。没有消息等。我在我的 .bashrc 中使用了以下内容 if [ -f ~/.bash_completio
我正在尝试构建一个 bash 完成例程,它将建议命令行标志和合适的标志值。例如在下面 fstcompose 命令我想比赛套路先建议 compose_filter= 标志,然后建议来自 [alt_seq
当我尝试在重定向符号后完成路径时,bash 完成的行为就好像它仍在尝试在重定向之前完成命令的参数一样。 例如: dpkg -l > /med标签 通过在 /med 之后点击 Tab我希望它完成通往 /
我的类中有几个 CAKeyframeAnimation 对象。 他们都以 self 为代表。 在我的animationDidStop函数中,我如何知道调用来自哪里? 是否有任何变量可以传递给 CAKe
我有一个带有 NSDateFormatter 的 NSTextField。格式化程序接受“mm/dd/yy”。 可以自动补全日期吗?因此,用户可以输入“mm”,格式化程序将完成当前月份和年份。 最佳答
有一个解决方案可以使用以下方法完成 NSTextField : - (NSArray *)control:(NSControl *)control textView:(NSTextView *)tex
我正在阅读 Passport 的文档,我注意到 serialize()和 deserialize() done()被调用而不被返回。 但是,当使用 passport.use() 设置新策略时在回调函数
在 ubuntu 11.10 上的 Firefox 8.0 中,尽管 img.complete 为 false,但仍会调用 onload 函数 draw。我设法用 setTimeout hack 解决
假设我有两个与两个并行执行的计算相对应的 future 。我如何等到第一个 future 准备好?理想情况下,我正在寻找类似于Python asyncio's wait且参数为return_when=
我正在寻找一种 Java 7 数据结构,其行为类似于 java.util.Queue,并且还具有“最终项目已被删除”的概念。 例如,应可以表达如下概念: while(!endingQueue.isFi
这是一个简单的问题。 if ($('.dataTablePageList')) { 我想做的是执行一个 if 语句,该语句表示如果具有 dataTablesPageList 类的对象也具有 menu
我用replaceWith批量替换了许多div中的html。替换后,我使用 jTruncate 来截断文本。然而它不起作用,因为在执行时,replaceWith 还没有完成。 我尝试了回调技巧 ( H
有没有办法调用 javascript 表单 submit() 函数或 JQuery $.submit() 函数并确保它完成提交过程?具体来说,在一个表单中,我试图在一个 IFrame 中提交一个表单。
我有以下方法: function animatePortfolio(fadeElement) { fadeElement.children('article').each(function(i
我刚刚开始使用 AndEngine, 我正在像这样移动 Sprite : if(pValueY < 0 && !jumping) { jumping =
我正在使用 asynctask 来执行冗长的操作,例如数据库读取。我想开始一个新 Activity 并在所有异步任务完成后呈现其内容。实现这一目标的最佳方法是什么? 我知道 onPostExecute
我有一个脚本需要命令名称和该命令的参数作为参数。 所以我想编写一个完成函数来完成命令的名称并完成该命令的参数。 所以我可以这样完成命令的名称 if [[ "$COMP_CWORD" == 1 ]];
我的应用程序有一个相当奇怪的行为。我在 BOOT_COMPLETE 之后启动我的应用程序,因此在我启动设备后它是可见的。 GUI 响应迅速,一切正常,直到我调用 finish(),按下按钮时,什么都没
我是一名优秀的程序员,十分优秀!