コード例 #1
0
        /// <summary>
        /// An MP4 muxing will be created for with the Per-Title video stream template and the audio stream.
        /// This muxing must define either {uuid} or {bitrate} in the output path.
        /// These placeholders will be replaced during the generation of the Per-Title.
        /// </summary>
        /// <param name="encoding">The reference of the encoding</param>
        /// <param name="output">The output the files should be written to</param>
        /// <param name="videoStream">The Per-Title template video stream</param>
        /// <param name="audioStream">The audio stream</param>
        private static Mp4 CreateMP4Muxing(Encoding.Encoding encoding, BaseOutput output, Stream videoStream, Stream audioStream)
        {
            var encodingOutput = new Encoding.Output
            {
                OutputPath = System.IO.Path.Combine(S3_OUTPUT_BASE_PATH, "{width}_{bitrate}_{uuid}"),
                OutputId   = output.Id,
                Acl        = new List <Acl> {
                    new Acl {
                        Permission = Permission.PUBLIC_READ
                    }
                }
            };

            var muxing = new Mp4
            {
                Filename = "video.mp4",
                Outputs  = new List <Encoding.Output> {
                    encodingOutput
                },
                Streams = new List <MuxingStream> {
                    new MuxingStream {
                        StreamId = videoStream.Id
                    }, new MuxingStream {
                        StreamId = audioStream.Id
                    }
                }
            };

            return(bitmovin.Encoding.Encoding.Mp4.Create(encoding.Id, muxing));
        }
コード例 #2
0
        /// <summary>
        /// The encoding will be started with the per title object and the auto representations set. If the auto
        /// representation is set, stream configurations will be automatically added to the Per-Title profile. In that case
        /// at least one PER_TITLE_TEMPLATE stream configuration must be available. All other configurations will be
        /// automatically chosen by the Per-Title algorithm. All relevant settings for streams and muxings will be taken from
        /// the closest PER_TITLE_TEMPLATE stream defined. The closest stream will be chosen based on the resolution
        /// specified in the codec configuration.
        /// </summary>
        /// <param name="encoding">The reference of the encoding</param>
        private static void StartEncoding(Encoding.Encoding encoding)
        {
            var h264PerTitleConfig = new H264PerTitleConfiguration
            {
                AutoRepresentations = new AutoRepresentation()
            };

            var startEncodingRequest = new StartEncodingRequest
            {
                PerTitle     = new PerTitle(h264PerTitleConfig),
                EncodingMode = EncodingMode.THREE_PASS,
            };

            bitmovin.Encoding.Encoding.Start(encoding.Id, startEncodingRequest);

            var encodingTask = bitmovin.Encoding.Encoding.RetrieveStatus(encoding.Id);

            // Wait for the encoding to finish
            while (encodingTask.Status != Status.ERROR && encodingTask.Status != Status.FINISHED)
            {
                encodingTask = bitmovin.Encoding.Encoding.RetrieveStatus(encoding.Id);
                Console.WriteLine("Status: {0}, Progress: {1}%", encodingTask.Status, encodingTask.Progress);
                Thread.Sleep(5000);
            }

            if (encodingTask.Status != Status.FINISHED)
            {
                Console.WriteLine("Encoding could not be finished successfully.");
                return;
            }
        }
コード例 #3
0
        /// <summary>
        /// This will create the Per-Title template video stream. This stream will be used as a template for the Per-Title
        /// encoding.The Codec Configuration, Muxings, DRMs and Filters applied to the generated Per-Title profile will be
        /// based on the same, or closest matching resolutions defined in the template.
        /// Please note, that template streams are not necessarily used for the encoding - they are just used as template.
        /// </summary>
        /// <param name="encoding">The reference of the encoding</param>
        /// <param name="videoInputStream">The input stream that should be encoded</param>
        /// <returns>The created Per-Title template video stream. This will be used later for the MP4 muxing</returns>
        private static Stream CreatePerTitleVideoStream(Encoding.Encoding encoding, InputStream videoInputStream)
        {
            var videoConfig = bitmovin.Codec.H264.Create(new H264VideoConfiguration
            {
                Name    = "H264_Profile",
                Profile = H264Profile.HIGH
            });

            return(bitmovin.Encoding.Encoding.Stream.Create(encoding.Id, new Stream
            {
                InputStreams = new List <InputStream> {
                    videoInputStream
                },
                CodecConfigId = videoConfig.Id,
                Mode = StreamMode.PER_TITLE_TEMPLATE
            }));
        }
コード例 #4
0
        /// <summary>
        /// This will create the audio stream that will be encoded with the given codec configuration.
        /// </summary>
        /// <param name="encoding">The reference of the encoding</param>
        /// <param name="audioInputStream">The input stream that should be encoded</param>
        /// <returns>The created audio stream. This will be used later for the MP4 muxing</returns>
        private static Stream CreateAudioStream(Encoding.Encoding encoding, InputStream audioInputStream)
        {
            var audioConfig = bitmovin.Codec.Aac.Create(new AACAudioConfiguration
            {
                Name    = "AAC_Profile_128k",
                Bitrate = 128000,
                Rate    = 48000
            });

            return(bitmovin.Encoding.Encoding.Stream.Create(encoding.Id, new Stream
            {
                InputStreams = new List <InputStream> {
                    audioInputStream
                },
                CodecConfigId = audioConfig.Id,
                Mode = StreamMode.STANDARD
            }));
        }