|
@@ -1134,14 +1134,14 @@ extension PQStuckPointEditerController {
|
|
|
if sticker.type == StickerType.VIDEO.rawValue {
|
|
|
let asset: AVURLAsset = AVURLAsset(url: URL(fileURLWithPath: documensDirectory + sticker.locationPath), options: nil)
|
|
|
|
|
|
- var realUsedMusicDuration = 0.0
|
|
|
+
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BFLog(message: "单个视频\(sticker.locationPath)时长::\(CMTimeGetSeconds(asset.duration)) ,clipNum is:\(sticker.clipCount)")
|
|
|
var lastOutTime: Float64 = 0.0
|
|
|
- for clipindex in 0 ... sticker.clipCount - 1 {
|
|
|
+ for clipindex in 0 ... sticker.clipCount {
|
|
|
|
|
|
let deepCopyStickerDecoderTime: TimeInterval = Date().timeIntervalSince1970
|
|
|
|
|
@@ -1158,44 +1158,36 @@ extension PQStuckPointEditerController {
|
|
|
tempSpeed = (totalClipNum + clipindex) % 2 == 0 ? maxSpeed : minSpeed
|
|
|
}
|
|
|
|
|
|
- if totalClipNum + 1 + clipindex < finallyStuckPoints.count {
|
|
|
+ if totalClipNum + clipindex + 1 < finallyStuckPoints.count {
|
|
|
deepCopySticker?.speedRate = tempSpeed
|
|
|
|
|
|
|
|
|
|
|
|
- var tempModel_In = lastOutTime
|
|
|
- var tempOut = lastOutTime + Float64(tempSpeed) * Float64(finallyStuckPoints[totalClipNum + 1 + clipindex] - finallyStuckPoints[totalClipNum + clipindex])
|
|
|
+ let tempModel_In = lastOutTime
|
|
|
+ let tempOut = lastOutTime + Float64(tempSpeed) * Float64(finallyStuckPoints[totalClipNum + 1 + clipindex] - finallyStuckPoints[totalClipNum + clipindex])
|
|
|
|
|
|
|
|
|
- var tempTimelineIn = Float64(finallyStuckPoints[totalClipNum + clipindex])
|
|
|
- var timelineOut = Float64(finallyStuckPoints[totalClipNum + 1 + clipindex])
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+ let tempTimelineIn = Float64(finallyStuckPoints[totalClipNum + clipindex])
|
|
|
+ let timelineOut = Float64(finallyStuckPoints[totalClipNum + 1 + clipindex])
|
|
|
|
|
|
|
|
|
if tempOut > CMTimeGetSeconds(asset.duration) {
|
|
|
BFLog(message: "最后一点视频素材不够卡点时长要做变速C处理 差\(tempOut - CMTimeGetSeconds(asset.duration))")
|
|
|
|
|
|
- let lastAssetDuration = realUsedMusicDuration - tempOut
|
|
|
+ let lastAssetDuration = CMTimeGetSeconds(asset.duration) - lastOutTime
|
|
|
let pointDuration = timelineOut - tempTimelineIn
|
|
|
+
|
|
|
let needSpeed = lastAssetDuration / pointDuration
|
|
|
|
|
|
if tempSpeed >= 1 {
|
|
|
- if needSpeed > 0.4 * Double(tempSpeed) {
|
|
|
- deepCopySticker?.speedRate = tempSpeed
|
|
|
+ if needSpeed >= 0.4 * Double(tempSpeed) {
|
|
|
+ deepCopySticker?.speedRate = Float(needSpeed)
|
|
|
} else {
|
|
|
continue
|
|
|
}
|
|
|
} else {
|
|
|
- if needSpeed > 0.4 * Double(tempSpeed) && needSpeed > 0.2 {
|
|
|
- deepCopySticker?.speedRate = tempSpeed
|
|
|
+ if needSpeed >= 0.4 * Double(tempSpeed) && needSpeed >= 0.2 {
|
|
|
+ deepCopySticker?.speedRate = Float(needSpeed)
|
|
|
} else {
|
|
|
continue
|
|
|
}
|
|
@@ -1442,17 +1434,50 @@ extension PQStuckPointEditerController {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-
|
|
|
+
|
|
|
if useAssestDurationTemp < assetDuration {
|
|
|
|
|
|
+
|
|
|
+ var tempSpeed: Float = 1.0
|
|
|
+ if model == .createStickersModelSpeed {
|
|
|
+ tempSpeed = (sticker.clipCount) % 2 == 0 ? maxSpeed : minSpeed
|
|
|
+ }
|
|
|
+
|
|
|
+ let lastAssetDuration = Float(CMTimeGetSeconds(asset.duration)) - useAssestDurationTemp
|
|
|
+
|
|
|
lastPointIndex = sticker.clipCount % stuckPointsTemp.count
|
|
|
+
|
|
|
let a = stuckPointsTemp[lastPointIndex ?? 0]
|
|
|
+ var b:Float = 0.0
|
|
|
if((lastPointIndex ?? 0) + 1 < stuckPointsTemp.count){
|
|
|
- let b = stuckPointsTemp[(lastPointIndex ?? 0) + 1]
|
|
|
- finallyStuckPoints.append((finallyStuckPoints.last ?? 0.0) + (b - a))
|
|
|
-
|
|
|
- sticker.clipCount = sticker.clipCount + 1
|
|
|
+ b = stuckPointsTemp[(lastPointIndex ?? 0) + 1]
|
|
|
+
|
|
|
+ let pointDuration = b - a
|
|
|
+
|
|
|
+ let needSpeed = lastAssetDuration / pointDuration
|
|
|
+
|
|
|
+
|
|
|
+ if tempSpeed >= 1 {
|
|
|
+ if needSpeed >= 0.4 * tempSpeed {
|
|
|
+
|
|
|
+ finallyStuckPoints.append((finallyStuckPoints.last ?? 0.0) + (b - a))
|
|
|
+ sticker.clipCount = sticker.clipCount + 1
|
|
|
+ }else{
|
|
|
+ BFLog(message: "条件不满足不用补位")
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ if needSpeed >= 0.4 * tempSpeed && needSpeed >= 0.2 {
|
|
|
+
|
|
|
+ finallyStuckPoints.append((finallyStuckPoints.last ?? 0.0) + (b - a))
|
|
|
+ sticker.clipCount = sticker.clipCount + 1
|
|
|
+ }else{
|
|
|
+ BFLog(message: "条件不满足不用补位")
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
}
|
|
|
+
|
|
|
+
|
|
|
|
|
|
}
|
|
|
}
|