Ios 向未显示的视频文本添加水印

Ios 向未显示的视频文本添加水印,ios,swift3,avfoundation,Ios,Swift3,Avfoundation,我不熟悉斯威夫特。我正在制作一个应用程序,可以添加自定义动画和效果,如水印到视频中。我写这段代码是为了添加一个水印。问题是显示了水印矩形,也显示了图像,但没有显示文本。这是密码 let videoAsset = AVURLAsset(url: URL(fileURLWithPath: path!)) let mixComposition: AVMutableComposition = AVMutableComposition() let mutableTrack = mixCom

我不熟悉斯威夫特。我正在制作一个应用程序,可以添加自定义动画和效果,如水印到视频中。我写这段代码是为了添加一个水印。问题是显示了水印矩形,也显示了图像,但没有显示文本。这是密码

let videoAsset = AVURLAsset(url: URL(fileURLWithPath: path!))
    let mixComposition: AVMutableComposition = AVMutableComposition()
    let mutableTrack = mixComposition.addMutableTrack(withMediaType: AVMediaTypeVideo, preferredTrackID: kCMPersistentTrackID_Invalid)

    let assetTrack = videoAsset.tracks(withMediaType: AVMediaTypeVideo)[0]
    let timeRangeForVideoAsset = CMTimeRangeMake(kCMTimeZero, videoAsset.duration)
    print("1 ...")
    do{
        try mutableTrack.insertTimeRange(timeRangeForVideoAsset, of: assetTrack, at: kCMTimeZero)
    }catch{
        print("Error in adding time range")
    }
    mutableTrack.preferredTransform = assetTrack.preferredTransform

    let imageLayer: CALayer = CALayer()
    var im = Bundle.main.path(forResource: "Ground", ofType: "png")
    let image = UIImage(contentsOfFile: im!)
    print("2 ...")
    imageLayer.contents = image?.cgImage
    imageLayer.opacity = 0.7
    imageLayer.frame = CGRect(x: 0, y: 100, width: self.view.frame.width, height: 50)

    let videoSize = assetTrack.naturalSize
    let parentLayer = CALayer()
    let videoLayer = CALayer()

    parentLayer.frame = CGRect(x: 0, y: 0, width: assetTrack.naturalSize.width, height: assetTrack.naturalSize.height)
    videoLayer.frame = CGRect(x: 0, y: 0, width: assetTrack.naturalSize.width, height: assetTrack.naturalSize.height)
    print("3 ...")

    let titleLayer = CATextLayer()
    titleLayer.backgroundColor = UIColor.white.cgColor
    titleLayer.string = "Dummy text"
    titleLayer.foregroundColor = UIColor.black.cgColor
    titleLayer.font = UIFont(name: "Helvetica", size: 28)
    titleLayer.opacity = 1.0
    titleLayer.shadowOpacity = 0.5
    titleLayer.alignmentMode = kCAAlignmentCenter
    titleLayer.frame = CGRect(x: 0, y: 50, width: self.view.frame.width, height: 50)
    parentLayer.addSublayer(videoLayer)
    parentLayer.addSublayer(imageLayer)
    parentLayer.addSublayer(titleLayer)

    let videoComp = AVMutableVideoComposition()
    videoComp.renderSize = videoSize
    videoComp.frameDuration = CMTimeMake(1, 30)
    videoComp.animationTool = AVVideoCompositionCoreAnimationTool(postProcessingAsVideoLayer: videoLayer, in: parentLayer)
    print("4 ...")
    let instruction = AVMutableVideoCompositionInstruction()
    instruction.timeRange = CMTimeRangeMake(kCMTimeZero, mixComposition.duration)
    var layerInstruction = AVMutableVideoCompositionLayerInstruction(assetTrack: assetTrack)
    instruction.layerInstructions = [layerInstruction]
    videoComp.instructions = [instruction]
    print("5 ...")
    let assetExport = AVAssetExportSession(asset: mixComposition, presetName: AVAssetExportPresetHighestQuality)
    assetExport?.videoComposition = videoComp
    let videoName = "markedVideo.mov"
    var exPath = NSTemporaryDirectory().appending(videoName)
    if(FileManager.default.fileExists(atPath: exPath)){
        do{
            try FileManager.default.removeItem(atPath: exPath)
        }
        catch{
            print("File Not Deleted")
        }
    }
    print("6 ...")
    assetExport?.outputFileType = AVFileTypeQuickTimeMovie
    assetExport?.outputURL = URL(fileURLWithPath: exPath)
    assetExport?.shouldOptimizeForNetworkUse = true
    assetExport?.exportAsynchronously(completionHandler: {
        print("Success ...")
        self.playWithMPKit(path: exPath)
    })

请帮帮我,我做错了什么。我将非常感谢您。

我在申请时注意到了这个问题

我的应用程序的一部分功能是为我的视频添加字幕。我曾尝试使用CATextLayer将我的字幕呈现给我的AVMutableComposition obj。但我也失败了 然后我尝试使用一个容器作为一种桥梁。因此我将我的CATextLayer放入CALayer,然后将这个CALayer添加到animationTool的子层

let subtitle = CATextLayer()
/*
   setup subtitle's properties...
*/
let subtitle_container = CALayer()
/*
   setup container's frame/position/rotation/animations<-(such as subtitles fade in / out effects)...
*/
subtitle_container.addSublayer(subtitle)
parentLayer.addSublayer(subtitle_container)
如上所述,我使用了
subtitle\u container
,它是我提到的
CALayer
,并将容器添加到
renderingLayer
,它是
parentLayer

这是否可能是因为水印的帧不正确,所以只渲染容器?我将容器的宽度和高度设置为输出视频的宽度和高度,所以我有了一个全屏容器,之后,调整CATextLayer变得更加容易


有什么对你有用的吗?

@Mark你能帮我吗?我从来没有对水印进行过编码,所以我帮不了你。很抱歉。添加文本层后,还需要显示它。因此,在调整文本层框架后添加
titleLayer.display()
,仍然没有帮助。首先,它显示了文本层的背景颜色设置,但现在它甚至没有显示。
        RAGE_SubtitleModel * m = subtitleModelArray[i];
        // ^this model contained the frame of subtitle, start time , end time.

        CGFloat subtitle_startTime = CMTimeGetSeconds(m.timeMapping.target.start);
        CGFloat subtitle_duration  = CMTimeGetSeconds(m.timeMapping.target.duration);
        
        CALayer * subtitle_container = [CALayer layer];
        CATextLayer * subtitle_layer = [CATextLayer layer];
        //  Font
        [subtitle_layer setFont:(__bridge CFTypeRef _Nullable)(m.font.fontName)];
        //  Font Size
        [subtitle_layer setFontSize:m.fontSize * MAX(ratioW, ratioH)];
        //  Background Color
        [subtitle_layer setBackgroundColor:[UIColor clearColor].CGColor];
        //  Subtitle Color
        [subtitle_layer setForegroundColor:m.color.CGColor];
        //  Subtitle Content
        [subtitle_layer setString:m.string];
        //  Subtitle Alignment Type
        [subtitle_layer setAlignmentMode:kCAAlignmentLeft];
        
        [subtitle_layer setContentsScale:SCREEN_SCALE];
        //  Subtitle Position
        [subtitle_container setFrame:CGRectMake(0,
                                                 0,
                                                targetSize.width,
                                                targetSize.height)];
        
        [subtitle_layer setFrame:CGRectMake(0, 0, m.frame.size.width * ratioW, m.frame.size.height * ratioH)];

        [subtitle_layer setAnchorPoint:CGPointMake(.5,.5)];
        
        [subtitle_layer setPosition:CGPointMake(m.frame.origin.x * ratioW + m.frame.size.width * ratioW * .5f,
                                                targetSize.height - m.frame.origin.y * ratioH - m.frame.size.height * ratioH * .5f)];
        
        [subtitle_container addSublayer:subtitle_layer];
        [renderingLayer addSublayer:subtitle_container];