123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184 |
- /*jshint node:true*/
- 'use strict';
- var utils = require('../utils');
- /*
- *! Video-related methods
- */
- module.exports = function(proto) {
- /**
- * Disable video in the output
- *
- * @method FfmpegCommand#noVideo
- * @category Video
- * @aliases withNoVideo
- *
- * @return FfmpegCommand
- */
- proto.withNoVideo =
- proto.noVideo = function() {
- this._currentOutput.video.clear();
- this._currentOutput.videoFilters.clear();
- this._currentOutput.video('-vn');
- return this;
- };
- /**
- * Specify video codec
- *
- * @method FfmpegCommand#videoCodec
- * @category Video
- * @aliases withVideoCodec
- *
- * @param {String} codec video codec name
- * @return FfmpegCommand
- */
- proto.withVideoCodec =
- proto.videoCodec = function(codec) {
- this._currentOutput.video('-vcodec', codec);
- return this;
- };
- /**
- * Specify video bitrate
- *
- * @method FfmpegCommand#videoBitrate
- * @category Video
- * @aliases withVideoBitrate
- *
- * @param {String|Number} bitrate video bitrate in kbps (with an optional 'k' suffix)
- * @param {Boolean} [constant=false] enforce constant bitrate
- * @return FfmpegCommand
- */
- proto.withVideoBitrate =
- proto.videoBitrate = function(bitrate, constant) {
- bitrate = ('' + bitrate).replace(/k?$/, 'k');
- this._currentOutput.video('-b:v', bitrate);
- if (constant) {
- this._currentOutput.video(
- '-maxrate', bitrate,
- '-minrate', bitrate,
- '-bufsize', '3M'
- );
- }
- return this;
- };
- /**
- * Specify custom video filter(s)
- *
- * Can be called both with one or many filters, or a filter array.
- *
- * @example
- * command.videoFilters('filter1');
- *
- * @example
- * command.videoFilters('filter1', 'filter2=param1=value1:param2=value2');
- *
- * @example
- * command.videoFilters(['filter1', 'filter2']);
- *
- * @example
- * command.videoFilters([
- * {
- * filter: 'filter1'
- * },
- * {
- * filter: 'filter2',
- * options: 'param=value:param=value'
- * }
- * ]);
- *
- * @example
- * command.videoFilters(
- * {
- * filter: 'filter1',
- * options: ['value1', 'value2']
- * },
- * {
- * filter: 'filter2',
- * options: { param1: 'value1', param2: 'value2' }
- * }
- * );
- *
- * @method FfmpegCommand#videoFilters
- * @category Video
- * @aliases withVideoFilter,withVideoFilters,videoFilter
- *
- * @param {...String|String[]|Object[]} filters video filter strings, string array or
- * filter specification array, each with the following properties:
- * @param {String} filters.filter filter name
- * @param {String|String[]|Object} [filters.options] filter option string, array, or object
- * @return FfmpegCommand
- */
- proto.withVideoFilter =
- proto.withVideoFilters =
- proto.videoFilter =
- proto.videoFilters = function(filters) {
- if (arguments.length > 1) {
- filters = [].slice.call(arguments);
- }
- if (!Array.isArray(filters)) {
- filters = [filters];
- }
- this._currentOutput.videoFilters(utils.makeFilterStrings(filters));
- return this;
- };
- /**
- * Specify output FPS
- *
- * @method FfmpegCommand#fps
- * @category Video
- * @aliases withOutputFps,withOutputFPS,withFpsOutput,withFPSOutput,withFps,withFPS,outputFPS,outputFps,fpsOutput,FPSOutput,FPS
- *
- * @param {Number} fps output FPS
- * @return FfmpegCommand
- */
- proto.withOutputFps =
- proto.withOutputFPS =
- proto.withFpsOutput =
- proto.withFPSOutput =
- proto.withFps =
- proto.withFPS =
- proto.outputFPS =
- proto.outputFps =
- proto.fpsOutput =
- proto.FPSOutput =
- proto.fps =
- proto.FPS = function(fps) {
- this._currentOutput.video('-r', fps);
- return this;
- };
- /**
- * Only transcode a certain number of frames
- *
- * @method FfmpegCommand#frames
- * @category Video
- * @aliases takeFrames,withFrames
- *
- * @param {Number} frames frame count
- * @return FfmpegCommand
- */
- proto.takeFrames =
- proto.withFrames =
- proto.frames = function(frames) {
- this._currentOutput.video('-vframes', frames);
- return this;
- };
- };
|