mirror of
https://github.com/stashapp/stash.git
synced 2025-12-17 12:24:38 +03:00
Add configurable transcode sizes (#178)
This commit is contained in:
@@ -3,13 +3,56 @@ package ffmpeg
|
||||
import (
|
||||
"io"
|
||||
"os"
|
||||
"strconv"
|
||||
|
||||
"github.com/stashapp/stash/pkg/models"
|
||||
)
|
||||
|
||||
type TranscodeOptions struct {
|
||||
OutputPath string
|
||||
OutputPath string
|
||||
MaxTranscodeSize models.StreamingResolutionEnum
|
||||
}
|
||||
|
||||
func calculateTranscodeScale(probeResult VideoFile, maxTranscodeSize models.StreamingResolutionEnum) string {
|
||||
maxSize := 0
|
||||
switch maxTranscodeSize {
|
||||
case models.StreamingResolutionEnumLow:
|
||||
maxSize = 240
|
||||
case models.StreamingResolutionEnumStandard:
|
||||
maxSize = 480
|
||||
case models.StreamingResolutionEnumStandardHd:
|
||||
maxSize = 720
|
||||
case models.StreamingResolutionEnumFullHd:
|
||||
maxSize = 1080
|
||||
case models.StreamingResolutionEnumFourK:
|
||||
maxSize = 2160
|
||||
}
|
||||
|
||||
// get the smaller dimension of the video file
|
||||
videoSize := probeResult.Height
|
||||
if probeResult.Width < videoSize {
|
||||
videoSize = probeResult.Width
|
||||
}
|
||||
|
||||
// if our streaming resolution is larger than the video dimension
|
||||
// or we are streaming the original resolution, then just set the
|
||||
// input width
|
||||
if maxSize >= videoSize || maxSize == 0 {
|
||||
return "iw:-2"
|
||||
}
|
||||
|
||||
// we're setting either the width or height
|
||||
// we'll set the smaller dimesion
|
||||
if probeResult.Width > probeResult.Height {
|
||||
// set the height
|
||||
return "-2:" + strconv.Itoa(maxSize)
|
||||
}
|
||||
|
||||
return strconv.Itoa(maxSize) + ":-2"
|
||||
}
|
||||
|
||||
func (e *Encoder) Transcode(probeResult VideoFile, options TranscodeOptions) {
|
||||
scale := calculateTranscodeScale(probeResult, options.MaxTranscodeSize)
|
||||
args := []string{
|
||||
"-i", probeResult.Path,
|
||||
"-c:v", "libx264",
|
||||
@@ -18,7 +61,7 @@ func (e *Encoder) Transcode(probeResult VideoFile, options TranscodeOptions) {
|
||||
"-level", "4.2",
|
||||
"-preset", "superfast",
|
||||
"-crf", "23",
|
||||
"-vf", "scale=iw:-2",
|
||||
"-vf", "scale=" + scale,
|
||||
"-c:a", "aac",
|
||||
"-strict", "-2",
|
||||
options.OutputPath,
|
||||
@@ -26,7 +69,8 @@ func (e *Encoder) Transcode(probeResult VideoFile, options TranscodeOptions) {
|
||||
_, _ = e.run(probeResult, args)
|
||||
}
|
||||
|
||||
func (e *Encoder) StreamTranscode(probeResult VideoFile, startTime string) (io.ReadCloser, *os.Process, error) {
|
||||
func (e *Encoder) StreamTranscode(probeResult VideoFile, startTime string, maxTranscodeSize models.StreamingResolutionEnum) (io.ReadCloser, *os.Process, error) {
|
||||
scale := calculateTranscodeScale(probeResult, maxTranscodeSize)
|
||||
args := []string{}
|
||||
|
||||
if startTime != "" {
|
||||
@@ -36,7 +80,7 @@ func (e *Encoder) StreamTranscode(probeResult VideoFile, startTime string) (io.R
|
||||
args = append(args,
|
||||
"-i", probeResult.Path,
|
||||
"-c:v", "libvpx-vp9",
|
||||
"-vf", "scale=iw:-2",
|
||||
"-vf", "scale="+scale,
|
||||
"-deadline", "realtime",
|
||||
"-cpu-used", "5",
|
||||
"-row-mt", "1",
|
||||
|
||||
Reference in New Issue
Block a user