作者热门文章
- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
假设我有一个从 start time
零构造的 CMTimeRange
,并且 持续时间
40 秒。
我想通过 X 秒分隔符将此 CMTimeRange
分成多个 block 。所以 block 的总持续时间
将与原始持续时间相同duration
,并且每个startTime
将反射(reflect)endTime
。最后一个 block 将是剩余秒数的模数。
例如,对于 40 秒的视频和每个 block 15 秒的分隔符:
第一个 CMTimeRange
- 开始时间:0,持续时间:15 秒。
第二个 CMTimeRange
- 开始时间:15,持续时间:15 秒。
第三个 CMTimeRange
- 开始时间:30,持续时间:10 秒。 (剩下的)
我尝试过的:
我尝试对总持续时间使用
CMTimeSubtract
并再次使用结果,以递归方式直到 CMTime 无效,但它似乎不起作用。
我们将不胜感激任何帮助。
最好的问候,Roi
最佳答案
从 range.start
开始,创建给定长度的范围直到到达 range.end
:
func splitIntoChunks(range: CMTimeRange, length: CMTime) -> [CMTimeRange] {
var chunks: [CMTimeRange] = []
var from = range.start
while from < range.end {
chunks.append(CMTimeRange(start: from, duration: length).intersection(range))
from = from + length
}
return chunks
}
intersection
用于将最后一个 block 修剪到原始范围。
替代方案:
func splitIntoChunks(range: CMTimeRange, length: CMTime) -> [CMTimeRange] {
return stride(from: range.start.seconds, to: range.end.seconds, by: length.seconds).map {
CMTimeRange(start: CMTime(seconds: $0, preferredTimescale: length.timescale), duration: length)
.intersection(range)
}
}
使用自定义扩展使 CMTime
采用 Strideable
协议(protocol)
extension CMTime: Strideable {
public func distance(to other: CMTime) -> TimeInterval {
return other - self
}
public func advanced(by n: TimeInterval) -> CMTime {
return self + n
}
}
这可以进一步简化为
func splitIntoChunks(range: CMTimeRange, length: CMTime) -> [CMTimeRange] {
return stride(from: range.start, to: range.end, by: length.seconds).map {
CMTimeRange(start: $0, duration: length) .intersection(range)
}
}
在任何情况下,您都可能想要添加一张支票
precondition(length.seconds > 0, "length must be positive")
您的函数,以便在开发过程中检测无效调用。
关于ios - 将 CMTimeRange 拆分为多个 CMTimeRange block ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48787869/
我是一名优秀的程序员,十分优秀!