Start codec selection in admin
This commit is contained in:
parent
3b63d3680a
commit
f04f385f2b
13
web/.vscode/settings.json
vendored
Normal file
13
web/.vscode/settings.json
vendored
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
{
|
||||||
|
"cSpell.words": [
|
||||||
|
"Owncast",
|
||||||
|
"antd",
|
||||||
|
"bitrates",
|
||||||
|
"chartkick",
|
||||||
|
"framerates",
|
||||||
|
"kbps",
|
||||||
|
"linkify",
|
||||||
|
"paypal",
|
||||||
|
"toggleswitch"
|
||||||
|
]
|
||||||
|
}
|
125
web/components/config/video-codec-selector.tsx
Normal file
125
web/components/config/video-codec-selector.tsx
Normal file
@ -0,0 +1,125 @@
|
|||||||
|
import React, { useContext, useState, useEffect } from 'react';
|
||||||
|
import { Typography, Select } from 'antd';
|
||||||
|
import { ServerStatusContext } from '../../utils/server-status-context';
|
||||||
|
import { AlertMessageContext } from '../../utils/alert-message-context';
|
||||||
|
import {
|
||||||
|
API_VIDEO_CODEC,
|
||||||
|
RESET_TIMEOUT,
|
||||||
|
postConfigUpdateToAPI,
|
||||||
|
} from '../../utils/config-constants';
|
||||||
|
import {
|
||||||
|
createInputStatus,
|
||||||
|
StatusState,
|
||||||
|
STATUS_ERROR,
|
||||||
|
STATUS_PROCESSING,
|
||||||
|
STATUS_SUCCESS,
|
||||||
|
} from '../../utils/input-statuses';
|
||||||
|
import FormStatusIndicator from './form-status-indicator';
|
||||||
|
|
||||||
|
|
||||||
|
export default function CodecSelector() {
|
||||||
|
const serverStatusData = useContext(ServerStatusContext);
|
||||||
|
const { serverConfig, setFieldInConfigState } = serverStatusData || {};
|
||||||
|
const { videoCodec, supportedCodecs } = serverConfig || {};
|
||||||
|
const { Title } = Typography;
|
||||||
|
const { Option } = Select;
|
||||||
|
const [submitStatus, setSubmitStatus] = useState<StatusState>(null);
|
||||||
|
const { setMessage } = useContext(AlertMessageContext);
|
||||||
|
const [selectedCodec, setSelectedCodec] = useState(videoCodec);
|
||||||
|
|
||||||
|
let resetTimer = null;
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
setSelectedCodec(videoCodec);
|
||||||
|
}, [videoCodec]);
|
||||||
|
|
||||||
|
const resetStates = () => {
|
||||||
|
setSubmitStatus(null);
|
||||||
|
resetTimer = null;
|
||||||
|
clearTimeout(resetTimer);
|
||||||
|
};
|
||||||
|
|
||||||
|
async function handleChange(value) {
|
||||||
|
console.log(`selected ${value}`);
|
||||||
|
setSelectedCodec(value);
|
||||||
|
|
||||||
|
await postConfigUpdateToAPI({
|
||||||
|
apiPath: API_VIDEO_CODEC,
|
||||||
|
data: { value: value },
|
||||||
|
onSuccess: () => {
|
||||||
|
setFieldInConfigState({
|
||||||
|
fieldName: 'videoCodec',
|
||||||
|
value: value,
|
||||||
|
path: 'videoSettings',
|
||||||
|
});
|
||||||
|
setSubmitStatus(createInputStatus(STATUS_SUCCESS, 'Video codec updated.'));
|
||||||
|
|
||||||
|
resetTimer = setTimeout(resetStates, RESET_TIMEOUT);
|
||||||
|
if (serverStatusData.online) {
|
||||||
|
setMessage(
|
||||||
|
'Your latency buffer setting will take effect the next time you begin a live stream.',
|
||||||
|
);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onError: (message: string) => {
|
||||||
|
setSubmitStatus(createInputStatus(STATUS_ERROR, message));
|
||||||
|
|
||||||
|
resetTimer = setTimeout(resetStates, RESET_TIMEOUT);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
const items = supportedCodecs.map(function (codec) {
|
||||||
|
var title = codec;
|
||||||
|
if (title === 'libx264') {
|
||||||
|
title = 'Default (libx264)';
|
||||||
|
} else if (title === 'h264_nvenc') {
|
||||||
|
title = 'NVIDIA GPU acceleration';
|
||||||
|
} else if (title === 'h264_vaapi') {
|
||||||
|
title = 'VAAPI hardware encoding';
|
||||||
|
} else if (title === 'h264_qsv') {
|
||||||
|
title = 'Intel QuickSync';
|
||||||
|
} else if (title === 'h264_v4l2m2m') {
|
||||||
|
title = 'Video4Linux hardware encoding';
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Option key={codec} value={codec}>
|
||||||
|
{title}
|
||||||
|
</Option>
|
||||||
|
);
|
||||||
|
})
|
||||||
|
|
||||||
|
var description = '';
|
||||||
|
if (selectedCodec === 'libx264') {
|
||||||
|
description = 'libx264 is default codec and generally the choice you will want to use unless you have access to more specialized options. It is also likely the only option for running on shared VPS environments.';
|
||||||
|
} else if (selectedCodec === 'h264_nvenc') {
|
||||||
|
description = 'You can use your NVIDIA GPU for encoding if you have a modern NVIDIA card with encoding cores.';
|
||||||
|
} else if (selectedCodec === 'h264_vaapi') {
|
||||||
|
description = 'VAAPI may be supported by NVIDIA proprietary drivers, Mesa open-source drivers for AMD or Intel graphics cards.';
|
||||||
|
} else if (selectedCodec === 'h264_qsv') {
|
||||||
|
description = "Quick Sync Video is Intel's brand for its dedicated video encoding and decoding hardware core. May be an option if you have a modern Intel CPU with integrated graphics.";
|
||||||
|
} else if (selectedCodec === 'h264_v4l2m2m') {
|
||||||
|
description = "Video4Linux is an interface to multiple different hardware encoding platforms such as Intel and AMD."
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<Title level={3} className="section-title">
|
||||||
|
Video Codec
|
||||||
|
</Title>
|
||||||
|
<p className="description">
|
||||||
|
Blurb about codecs go here.
|
||||||
|
</p>
|
||||||
|
<div className="segment-slider-container">
|
||||||
|
<Select defaultValue={selectedCodec} value={selectedCodec} style={{ width: '100%' }} onChange={handleChange} >
|
||||||
|
{items}
|
||||||
|
</Select>
|
||||||
|
<FormStatusIndicator status={submitStatus} />
|
||||||
|
<p className="selected-value-note">
|
||||||
|
{description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</>
|
||||||
|
);
|
||||||
|
}
|
@ -1,8 +1,9 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { Typography, Row, Col } from 'antd';
|
import { Typography, Row, Col, Select } from 'antd';
|
||||||
|
|
||||||
import VideoVariantsTable from '../components/config/video-variants-table';
|
import VideoVariantsTable from '../components/config/video-variants-table';
|
||||||
import VideoLatency from '../components/config/video-latency';
|
import VideoLatency from '../components/config/video-latency';
|
||||||
|
import VideoCodecSelector from '../components/config/video-codec-selector';
|
||||||
|
|
||||||
const { Title } = Typography;
|
const { Title } = Typography;
|
||||||
|
|
||||||
@ -29,6 +30,9 @@ export default function ConfigVideoSettings() {
|
|||||||
<div className="form-module variants-table-module">
|
<div className="form-module variants-table-module">
|
||||||
<VideoVariantsTable />
|
<VideoVariantsTable />
|
||||||
</div>
|
</div>
|
||||||
|
<div className="form-module variants-table-module">
|
||||||
|
<VideoCodecSelector />
|
||||||
|
</div>
|
||||||
</Col>
|
</Col>
|
||||||
<Col md={24} lg={12}>
|
<Col md={24} lg={12}>
|
||||||
<div className="form-module latency-module">
|
<div className="form-module latency-module">
|
||||||
@ -39,3 +43,4 @@ export default function ConfigVideoSettings() {
|
|||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -99,4 +99,6 @@ export interface ConfigDetails {
|
|||||||
videoSettings: VideoSettingsFields;
|
videoSettings: VideoSettingsFields;
|
||||||
webServerPort: string;
|
webServerPort: string;
|
||||||
yp: ConfigDirectoryFields;
|
yp: ConfigDirectoryFields;
|
||||||
|
supportedCodecs: string[];
|
||||||
|
videoCodec: string;
|
||||||
}
|
}
|
||||||
|
@ -28,7 +28,8 @@ export const API_VIDEO_VARIANTS = '/video/streamoutputvariants';
|
|||||||
export const API_WEB_PORT = '/webserverport';
|
export const API_WEB_PORT = '/webserverport';
|
||||||
export const API_YP_SWITCH = '/directoryenabled';
|
export const API_YP_SWITCH = '/directoryenabled';
|
||||||
export const API_CHAT_DISABLE = '/chat/disable';
|
export const API_CHAT_DISABLE = '/chat/disable';
|
||||||
export const API_EXTERNAL_ACTIONS = '/externalactions';
|
export const API_EXTERNAL_ACTIONS = '/externalactions'
|
||||||
|
export const API_VIDEO_CODEC = '/video/codec';
|
||||||
|
|
||||||
export async function postConfigUpdateToAPI(args: ApiPostArgs) {
|
export async function postConfigUpdateToAPI(args: ApiPostArgs) {
|
||||||
const { apiPath, data, onSuccess, onError } = args;
|
const { apiPath, data, onSuccess, onError } = args;
|
||||||
|
@ -46,6 +46,8 @@ export const initialServerConfigState: ConfigDetails = {
|
|||||||
videoQualityVariants: [DEFAULT_VARIANT_STATE],
|
videoQualityVariants: [DEFAULT_VARIANT_STATE],
|
||||||
},
|
},
|
||||||
externalActions: [],
|
externalActions: [],
|
||||||
|
supportedCodecs: [],
|
||||||
|
videoCodec: '',
|
||||||
};
|
};
|
||||||
|
|
||||||
const initialServerStatusState = {
|
const initialServerStatusState = {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user