993 lines
		
	
	
		
			62 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			993 lines
		
	
	
		
			62 KiB
		
	
	
	
		
			PHP
		
	
	
	
<?php include ("./link/session.php") ?>
 | 
						|
<!doctype html>
 | 
						|
<html lang="uft-8">
 | 
						|
<head>
 | 
						|
    <?php include ("./public/head.inc") ?>
 | 
						|
</head>
 | 
						|
<body>
 | 
						|
<?php include ("./public/menu.inc") ?>
 | 
						|
<div data-simplebar>
 | 
						|
    <main class="page-content encoder" id="app" v-cloak>
 | 
						|
        <div class="row">
 | 
						|
            <div class="col-lg-12 mx-auto">
 | 
						|
                <div class="card">
 | 
						|
                    <div class="card-header bg-transparent">
 | 
						|
                        <div class="p-2 mb-0 d-flex align-items-end">
 | 
						|
                            <cn>全局配置</cn>
 | 
						|
                            <en>Overall config</en>
 | 
						|
                        </div>
 | 
						|
                    </div>
 | 
						|
                    <div class="card-body overflow-auto" >
 | 
						|
                        <div class="row">
 | 
						|
                            <div class="col-lg-12" v-if="Object.keys(globalConf).length !== 0">
 | 
						|
                                <div class="row">
 | 
						|
                                    <div class="col-1"></div>
 | 
						|
                                    <div class="col-11">
 | 
						|
                                        <div class="row">
 | 
						|
                                            <div class="col-2 text-center">
 | 
						|
                                                <cn>分辨率</cn>
 | 
						|
                                                <en>video size</en>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col-2 text-center">
 | 
						|
                                                <cn>编码方式</cn>
 | 
						|
                                                <en>codec</en>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col text-center">
 | 
						|
                                                <cn>码率控制</cn>
 | 
						|
                                                <en>rate control</en>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col text-center">
 | 
						|
                                                <cn>码率(kb/s)</cn>
 | 
						|
                                                <en>bitrate(kb/s)</en>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col text-center">
 | 
						|
                                                <cn>帧率</cn>
 | 
						|
                                                <en>framerate</en>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col text-center">
 | 
						|
                                                <cn>GOP(秒)</cn>
 | 
						|
                                                <en>GOP(sec)</en>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col text-center">
 | 
						|
                                                <cn>帧同步</cn>
 | 
						|
                                                <en>Sync</en>
 | 
						|
                                            </div>
 | 
						|
                                        </div>
 | 
						|
                                    </div>
 | 
						|
                                </div>
 | 
						|
                                <div class="row mt-1">
 | 
						|
                                    <div class="col-1 text-center p-0 pt-2">
 | 
						|
                                        <cn>主流参数</cn>
 | 
						|
                                        <en>Main stream</en>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col-11">
 | 
						|
                                        <div class="row">
 | 
						|
                                            <div class="col-2">
 | 
						|
                                                <multiple-select v-model:value1="globalConf.encv.width" v-model:value2="globalConf.encv.height" split="x">
 | 
						|
                                                    <option value="-1x-1">auto</option>
 | 
						|
                                                    <option v-if="Object.keys(hardwareConf).length > 0 && hardwareConf.capability.encode.maxSize === '4k'" value="3840x2160">4K</option>
 | 
						|
                                                    <option value="1920x1080">1080p</option>
 | 
						|
                                                    <option value="1280x720">720p</option>
 | 
						|
                                                    <option value="640x360">360p</option>
 | 
						|
                                                    <option value="1080x1920">1080x1920</option>
 | 
						|
                                                    <option value="720x1280">720x1280</option>
 | 
						|
                                                    <option value="360x640">360x640</option>
 | 
						|
                                                </multiple-select>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col-2">
 | 
						|
                                                <multiple-select v-model:value1="globalConf.encv.codec" v-model:value2="globalConf.encv.profile" split=",">
 | 
						|
                                                    <option value="h264,base">H.264 Base</option>
 | 
						|
                                                    <option value="h264,main">H.264 Main</option>
 | 
						|
                                                    <option value="h264,high">H.264 High</option>
 | 
						|
                                                    <option value="h265,main">H.265 Main</option>
 | 
						|
                                                    <option value="close,base">Close</option>
 | 
						|
                                                </multiple-select>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <select class="form-select" v-model="globalConf.encv.rcmode">
 | 
						|
                                                    <option value="cbr">CBR</option>
 | 
						|
                                                    <option value="vbr">VBR</option>
 | 
						|
                                                    <option value="avbr">AVBR</option>
 | 
						|
                                                    <option value="fixqp">FIXQP</option>
 | 
						|
                                                </select>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <input type="text" class="form-control" v-model.trim.lazy="globalConf.encv.bitrate">
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <input type="text" class="form-control" v-model.trim.lazy="globalConf.encv.framerate">
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <input type="text" class="form-control" v-model.trim.lazy="globalConf.encv.gop">
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <multiple-select v-model:value1="globalConf.encv.syncTS" v-model:value2="globalConf.encv.syncTSMode" split=",">
 | 
						|
                                                    <option cn="芯象" en="Sinsam" value="true,sinsam" v-language-option></option>
 | 
						|
                                                    <option cn="简易" en="Normal" value="true,linkpi" v-language-option></option>
 | 
						|
                                                    <option cn="关闭" en="Close" value="false,linkpi" v-language-option></option>
 | 
						|
                                                </multiple-select>
 | 
						|
                                            </div>
 | 
						|
                                        </div>
 | 
						|
                                    </div>
 | 
						|
                                </div>
 | 
						|
                                
 | 
						|
                                <div class="row mt-1">
 | 
						|
                                    <div class="col-1 text-center p-0 pt-2">
 | 
						|
                                        <cn>辅流参数</cn>
 | 
						|
                                        <en>Sub stream</en>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col-11">
 | 
						|
                                        <div class="row">
 | 
						|
                                            <div class="col-2">
 | 
						|
                                                <multiple-select v-model:value1="globalConf.encv2.width" v-model:value2="globalConf.encv2.height" split="x">
 | 
						|
                                                    <option value="-1x-1">auto</option>
 | 
						|
                                                    <option v-if="Object.keys(hardwareConf).length > 0 && hardwareConf.capability.encode.maxSize === '4k'" value="3840x2160">4K</option>
 | 
						|
                                                    <option value="1920x1080">1080p</option>
 | 
						|
                                                    <option value="1280x720">720p</option>
 | 
						|
                                                    <option value="640x360">360p</option>
 | 
						|
                                                    <option value="1080x1920">1080x1920</option>
 | 
						|
                                                    <option value="720x1280">720x1280</option>
 | 
						|
                                                    <option value="360x640">360x640</option>
 | 
						|
                                                </multiple-select>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col-2">
 | 
						|
                                                <multiple-select v-model:value1="globalConf.encv2.codec" v-model:value2="globalConf.encv2.profile" split=",">
 | 
						|
                                                    <option value="h264,base">H.264 Base</option>
 | 
						|
                                                    <option value="h264,main">H.264 Main</option>
 | 
						|
                                                    <option value="h264,high">H.264 High</option>
 | 
						|
                                                    <option value="h265,main">H.265 Main</option>
 | 
						|
                                                    <option value="close,base">Close</option>
 | 
						|
                                                </multiple-select>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <select class="form-select" v-model="globalConf.encv2.rcmode">
 | 
						|
                                                    <option value="cbr">CBR</option>
 | 
						|
                                                    <option value="vbr">VBR</option>
 | 
						|
                                                    <option value="avbr">AVBR</option>
 | 
						|
                                                    <option value="fixqp">FIXQP</option>
 | 
						|
                                                </select>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <input type="text" class="form-control" v-model.trim.lazy="globalConf.encv2.bitrate">
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <input type="text" class="form-control" v-model.trim.lazy="globalConf.encv2.framerate">
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <input type="text" class="form-control" v-model.trim.lazy="globalConf.encv2.gop">
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <multiple-select v-model:value1="globalConf.encv2.syncTS" v-model:value2="globalConf.encv2.syncTSMode" split=",">
 | 
						|
                                                    <option cn="芯象" en="Sinsam" value="true,sinsam" v-language-option></option>
 | 
						|
                                                    <option cn="简易" en="Normal" value="true,linkpi" v-language-option></option>
 | 
						|
                                                    <option cn="关闭" en="Close" value="false,linkpi" v-language-option></option>
 | 
						|
                                                </multiple-select>
 | 
						|
                                            </div>
 | 
						|
                                        </div>
 | 
						|
                                    </div>
 | 
						|
                                </div>
 | 
						|
                                <hr >
 | 
						|
                                <div class="row">
 | 
						|
                                    <div class="col-1"></div>
 | 
						|
                                    <div class="col-11">
 | 
						|
                                        <div class="row">
 | 
						|
                                            <div class="col text-center">
 | 
						|
                                                <cn>编码格式</cn>
 | 
						|
                                                <en>codec</en>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col text-center">
 | 
						|
                                                <cn>音源</cn>
 | 
						|
                                                <en>source</en>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col text-center">
 | 
						|
                                                <cn>增益</cn>
 | 
						|
                                                <en>gain</en>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col text-center">
 | 
						|
                                                <cn>采样率</cn>
 | 
						|
                                                <en>samplerate</en>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col text-center">
 | 
						|
                                                <cn>声道</cn>
 | 
						|
                                                <en>channels</en>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col text-center">
 | 
						|
                                                <cn>码率(kb/s)</cn>
 | 
						|
                                                <en>bitrate(kb/s)</en>
 | 
						|
                                            </div>
 | 
						|
                                            <div v-if="Object.keys(hardwareConf).length > 0 && hardwareConf.model==='ENC8'" class="col text-center">
 | 
						|
                                                <cn>音轨</cn>
 | 
						|
                                                <en>audio track</en>
 | 
						|
                                            </div>
 | 
						|
                                        </div>
 | 
						|
                                    </div>
 | 
						|
                                </div>
 | 
						|
                                
 | 
						|
                                <div class="row mt-1">
 | 
						|
                                    <div class="col-1 text-center p-0 pt-2">
 | 
						|
                                        <cn>音频参数</cn>
 | 
						|
                                        <en>Audio config</en>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col-11">
 | 
						|
                                        <div class="row">
 | 
						|
                                            <div class="col">
 | 
						|
                                                <select class="form-select" v-model="globalConf.enca.codec">
 | 
						|
                                                    <option value="aac">AAC</option>
 | 
						|
                                                    <option value="pcma">PCMA</option>
 | 
						|
                                                    <option value="mp2">MPEG2</option>
 | 
						|
                                                    <option value="mp3">MP3</option>
 | 
						|
                                                    <option value="close" cn="关闭" en="close" v-language-option></option>
 | 
						|
                                                </select>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <select class="form-select" v-model="globalConf.enca.audioSrc">
 | 
						|
                                                    <option value="source">Default</option>
 | 
						|
                                                    <option v-if="Object.keys(hardwareConf).length > 0 && hardwareConf.function.line" value="line">Line</option>
 | 
						|
                                                    <option v-for="(item,index) in defaultConf" :key="index" :value="item.id">{{item.name}}</option>
 | 
						|
                                                </select>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <select class="form-select" v-model="globalConf.enca.gain">
 | 
						|
                                                    <option value="24">+24dB</option>
 | 
						|
                                                    <option value="18">+18dB</option>
 | 
						|
                                                    <option value="12">+12dB</option>
 | 
						|
                                                    <option value="6">+6dB</option>
 | 
						|
                                                    <option value="0">+0dB</option>
 | 
						|
                                                    <option value="-6">-6dB</option>
 | 
						|
                                                    <option value="-12">-12dB</option>
 | 
						|
                                                    <option value="-18">-18dB</option>
 | 
						|
                                                    <option value="-24">-24dB</option>
 | 
						|
                                                </select>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <select class="form-select" v-model="globalConf.enca.samplerate">
 | 
						|
                                                    <option value="-1">auto</option>
 | 
						|
                                                    <option value="16000">16K</option>
 | 
						|
                                                    <option value="32000">32K</option>
 | 
						|
                                                    <option value="44100">44.1K</option>
 | 
						|
                                                    <option value="48000">48K</option>
 | 
						|
                                                </select>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <select class="form-select" v-model="globalConf.enca.channels">
 | 
						|
                                                    <option cn="单声道" en="mono" value="1" v-language-option></option>
 | 
						|
                                                    <option cn="立体声" en="stereo" value="2" v-language-option></option>
 | 
						|
                                                </select>
 | 
						|
                                            </div>
 | 
						|
                                            <div class="col">
 | 
						|
                                                <input type="text" class="form-control" v-model.trim.lazy="globalConf.enca.bitrate">
 | 
						|
                                            </div>
 | 
						|
                                            <div v-if="Object.keys(hardwareConf).length > 0 && hardwareConf.model==='ENC8'" class="col text-center">
 | 
						|
                                                <select class="form-select" v-model.number="globalConf.enca.audioTrack">
 | 
						|
                                                    <option cn="源-Line" en="source-line" value="1" v-language-option></option>
 | 
						|
                                                    <option cn="源-Hdmi" en="source-hdmi" value="2" v-language-option></option>
 | 
						|
                                                </select>
 | 
						|
                                            </div>
 | 
						|
                                        </div>
 | 
						|
                                    </div>
 | 
						|
                                </div>
 | 
						|
                                <hr >
 | 
						|
                                <div class="row text-center mt-3">
 | 
						|
                                    <div class="col-lg-12">
 | 
						|
                                        <button type="button" class="btn  border-3 btn-primary me-2" @click="saveGlobalConfByLocal">
 | 
						|
                                            <cn>应用到全部</cn>
 | 
						|
                                            <en>Apply to all</en>
 | 
						|
                                        </button>
 | 
						|
                                    </div>
 | 
						|
                                </div>
 | 
						|
                            </div>
 | 
						|
                        </div>
 | 
						|
                    </div>
 | 
						|
                </div>
 | 
						|
            </div>
 | 
						|
        </div>
 | 
						|
        
 | 
						|
        <div class="row">
 | 
						|
            <div class="col-lg-12 mx-auto">
 | 
						|
                <ul class="nav nav-tabs nav-primary" role="tablist">
 | 
						|
                    <li class="nav-item" role="presentation">
 | 
						|
                        <a class="nav-link active" data-bs-toggle="tab" href="#tab1" role="tab" aria-selected="true">
 | 
						|
                            <div class="d-flex align-items-center">
 | 
						|
                                <div class="tab-icon"><i class="fa fa-sign-in me-1"></i></div>
 | 
						|
                                <div class="tab-title"><cn>编码参数</cn><en>Encode config</en></div>
 | 
						|
                            </div>
 | 
						|
                        </a>
 | 
						|
                    </li>
 | 
						|
                    <li class="nav-item" role="presentation">
 | 
						|
                        <a class="nav-link" data-bs-toggle="tab" href="#tab2" role="tab" aria-selected="false">
 | 
						|
                            <div class="d-flex align-items-center">
 | 
						|
                                <div class="tab-icon"><i class="fa-regular fa-file-video me-1"></i></div>
 | 
						|
                                <div class="tab-title"><cn>高级编码参数</cn><en>Advanced Encode config</en></div>
 | 
						|
                            </div>
 | 
						|
                        </a>
 | 
						|
                    </li>
 | 
						|
                    <li class="nav-item" role="presentation" v-if="Object.keys(hardwareConf).length > 0 && hardwareConf.chip !== '3559A' && hardwareConf.chip !== '3516E'">
 | 
						|
                        <a class="nav-link" data-bs-toggle="tab" href="#tab3" role="tab" aria-selected="false">
 | 
						|
                            <div class="d-flex align-items-center">
 | 
						|
                                <div class="tab-icon"><i class="fa-regular fa-image me-1"></i></div>
 | 
						|
                                <div class="tab-title"><cn>视频参数</cn><en>Video config</en></div>
 | 
						|
                            </div>
 | 
						|
                        </a>
 | 
						|
                    </li>
 | 
						|
                    <li class="nav-item" role="presentation">
 | 
						|
                        <a class="nav-link" data-bs-toggle="tab" href="#tab4" role="tab" aria-selected="false">
 | 
						|
                            <div class="d-flex align-items-center">
 | 
						|
                                <div class="tab-icon"><i class="fa-regular fa-file-audio me-1"></i></div>
 | 
						|
                                <div class="tab-title"><cn>音频参数</cn><en>Audio config</en></div>
 | 
						|
                            </div>
 | 
						|
                        </a>
 | 
						|
                    </li>
 | 
						|
                    <li class="nav-item" role="presentation">
 | 
						|
                        <a class="nav-link" data-bs-toggle="tab" href="#tab5" role="tab" aria-selected="false">
 | 
						|
                            <div class="d-flex align-items-center">
 | 
						|
                                <div class="tab-icon"><i class="fa-brands fa-internet-explorer me-1"></i></div>
 | 
						|
                                <div class="tab-title"><cn>网络输入</cn><en>Network stream</en></div>
 | 
						|
                            </div>
 | 
						|
                        </a>
 | 
						|
                    </li>
 | 
						|
                </ul>
 | 
						|
                <div class="tab-content py-3 pe-2 ps-2">
 | 
						|
                    <div class="tab-pane fade show active" id="tab1" role="tabpanel">
 | 
						|
                        <div class="row">
 | 
						|
                            <div class="col-2 text-center">
 | 
						|
                                <cn>频道名称</cn>
 | 
						|
                                <en>channel name</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col-2 text-center">
 | 
						|
                                <cn>分辨率</cn>
 | 
						|
                                <en>video size</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col-2 text-center">
 | 
						|
                                <cn>编码方式</cn>
 | 
						|
                                <en>codec</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>码率控制</cn>
 | 
						|
                                <en>rate control</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>码率(kb/s)</cn>
 | 
						|
                                <en>bitrate(kb/s)</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>帧率</cn>
 | 
						|
                                <en>framerate</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>GOP(秒)</cn>
 | 
						|
                                <en>GOP(sec)</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>帧同步</cn>
 | 
						|
                                <en>sync</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>开关</cn>
 | 
						|
                                <en>enable</en>
 | 
						|
                            </div>
 | 
						|
                        </div>
 | 
						|
                        <hr >
 | 
						|
                        <div class="row mt-1" v-for="(item,index) in handleEncConf" :key="item.id">
 | 
						|
                            <div class="col-lg-12">
 | 
						|
                                <div class="row">
 | 
						|
                                    <div class="col-2 text-center">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.name">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col-2">
 | 
						|
                                        <multiple-select v-model:value1="item.encv.width" v-model:value2="item.encv.height" split="x">
 | 
						|
                                            <option value="-1x-1">auto</option>
 | 
						|
                                            <option v-if="Object.keys(hardwareConf).length > 0 && hardwareConf.capability.encode.maxSize === '4k'" value="3840x2160">4K</option>
 | 
						|
                                            <option value="1920x1080">1080p</option>
 | 
						|
                                            <option value="1280x720">720p</option>
 | 
						|
                                            <option value="640x360">360p</option>
 | 
						|
                                            <option value="1080x1920">1080x1920</option>
 | 
						|
                                            <option value="720x1280">720x1280</option>
 | 
						|
                                            <option value="360x640">360x640</option>
 | 
						|
                                        </multiple-select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col-2">
 | 
						|
                                        <multiple-select v-model:value1="item.encv.codec" v-model:value2="item.encv.profile" split=",">
 | 
						|
                                            <option value="h264,base">H.264 Base</option>
 | 
						|
                                            <option value="h264,main">H.264 Main</option>
 | 
						|
                                            <option value="h264,high">H.264 High</option>
 | 
						|
                                            <option value="h265,main">H.265 Main</option>
 | 
						|
                                            <option value="close,base" cn="关闭" en="Close" v-language-option></option>
 | 
						|
                                        </multiple-select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <select class="form-select" v-model="item.encv.rcmode">
 | 
						|
                                            <option value="cbr">CBR</option>
 | 
						|
                                            <option value="vbr">VBR</option>
 | 
						|
                                            <option value="avbr">AVBR</option>
 | 
						|
                                            <option value="fixqp">FIXQP</option>
 | 
						|
                                        </select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv.bitrate">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv.framerate">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv.gop">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <multiple-select v-model:value1="item.encv.syncTS" v-model:value2="item.encv.syncTSMode" split=",">
 | 
						|
                                            <option cn="芯象" en="Sinsam" value="true,sinsam" v-language-option></option>
 | 
						|
                                            <option cn="简易" en="Normal" value="true,linkpi" v-language-option></option>
 | 
						|
                                            <option cn="关闭" en="Close" value="false,linkpi" v-language-option></option>
 | 
						|
                                        </multiple-select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col lp-align-center">
 | 
						|
                                        <bs-switch v-model="item.enable" ></bs-switch>
 | 
						|
                                    </div>
 | 
						|
                                </div>
 | 
						|
                                <div class="row mt-1">
 | 
						|
                                    <div class="col-2 text-center"></div>
 | 
						|
                                    <div class="col-2">
 | 
						|
                                        <multiple-select v-model:value1="item.encv2.width" v-model:value2="item.encv2.height" split="x">
 | 
						|
                                            <option value="-1x-1">auto</option>
 | 
						|
                                            <option v-if="Object.keys(hardwareConf).length > 0 && hardwareConf.capability.encode.maxSize === '4k'" value="3840x2160">4K</option>
 | 
						|
                                            <option value="1920x1080">1080p</option>
 | 
						|
                                            <option value="1280x720">720p</option>
 | 
						|
                                            <option value="640x360">360p</option>
 | 
						|
                                            <option value="1080x1920">1080x1920</option>
 | 
						|
                                            <option value="720x1280">720x1280</option>
 | 
						|
                                            <option value="360x640">360x640</option>
 | 
						|
                                        </multiple-select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col-2">
 | 
						|
                                        <multiple-select v-model:value1="item.encv2.codec" v-model:value2="item.encv2.profile" split=",">
 | 
						|
                                            <option value="h264,base">H.264 Base</option>
 | 
						|
                                            <option value="h264,main">H.264 Main</option>
 | 
						|
                                            <option value="h264,high">H.264 High</option>
 | 
						|
                                            <option value="h265,main">H.265 Main</option>
 | 
						|
                                            <option value="close,base" cn="关闭" en="Close" v-language-option></option>
 | 
						|
                                        </multiple-select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <select class="form-select" v-model="item.encv2.rcmode">
 | 
						|
                                            <option value="cbr">CBR</option>
 | 
						|
                                            <option value="vbr">VBR</option>
 | 
						|
                                            <option value="avbr">AVBR</option>
 | 
						|
                                            <option value="fixqp">FIXQP</option>
 | 
						|
                                        </select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv2.bitrate">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv2.framerate">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv2.gop">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <multiple-select v-model:value1="item.encv2.syncTS" v-model:value2="item.encv2.syncTSMode" split=",">
 | 
						|
                                            <option cn="芯象" en="Sinsam" value="true,sinsam" v-language-option></option>
 | 
						|
                                            <option cn="简易" en="Normal" value="true,linkpi" v-language-option></option>
 | 
						|
                                            <option cn="关闭" en="Close" value="false,linkpi" v-language-option></option>
 | 
						|
                                        </multiple-select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col lp-align-center">
 | 
						|
                                        <bs-switch v-model="item.enable2" ></bs-switch>
 | 
						|
                                    </div>
 | 
						|
                                </div>
 | 
						|
                                <hr >
 | 
						|
                            </div>
 | 
						|
                        </div>
 | 
						|
                    </div>
 | 
						|
                    
 | 
						|
                    <div class="tab-pane fade" id="tab2" role="tabpanel">
 | 
						|
                        <div class="row">
 | 
						|
                            <div class="col-2 text-center">
 | 
						|
                                <cn>频道名称</cn>
 | 
						|
                                <en>channel name</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>宽</cn>
 | 
						|
                                <en>width</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>高</cn>
 | 
						|
                                <en>height</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col-2 text-center">
 | 
						|
                                <cn>智能编码模式</cn>
 | 
						|
                                <en>smart encode</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>minQP</cn>
 | 
						|
                                <en>minQP</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>maxQP</cn>
 | 
						|
                                <en>maxQP</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>fixIQP</cn>
 | 
						|
                                <en>fixIQP</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>fixPQP</cn>
 | 
						|
                                <en>fixPQP</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>低延时编码</cn>
 | 
						|
                                <en>low latency</en>
 | 
						|
                            </div>
 | 
						|
                        </div>
 | 
						|
                        <hr >
 | 
						|
                        <div class="row mt-1" v-for="(item,index) in handleAdvConf" :key="item.id">
 | 
						|
                            <div class="col-lg-12">
 | 
						|
                                <div class="row">
 | 
						|
                                    <div class="col-2 text-center">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.name">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv.width">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv.height">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col-2">
 | 
						|
                                        <select class="form-control" v-model="item.encv.gopmode">
 | 
						|
                                            <option value="0">Normal</option>
 | 
						|
                                            <option value="1">SmartP</option>
 | 
						|
                                            <option value="2">DualP</option>
 | 
						|
                                            <option v-if="Object.keys(hardwareConf).length > 0 && hardwareConf.capability.encode.BFrame" value="3">BiPredB</option>
 | 
						|
                                        </select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv.minqp">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv.maxqp">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv.Iqp">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv.Pqp">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col lp-align-center">
 | 
						|
                                        <bs-switch v-model="item.encv.lowLatency" ></bs-switch>
 | 
						|
                                    </div>
 | 
						|
                                </div>
 | 
						|
                                <div class="row mt-1">
 | 
						|
                                    <div class="col-2 text-center"></div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv2.width">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv2.height">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col-2">
 | 
						|
                                        <select class="form-control" v-model="item.encv2.gopmode">
 | 
						|
                                            <option value="0">Normal</option>
 | 
						|
                                            <option value="1">SmartP</option>
 | 
						|
                                            <option value="2">DualP</option>
 | 
						|
                                            <option v-if="Object.keys(hardwareConf).length > 0 && hardwareConf.capability.encode.BFrame" value="3">BiPredB</option>
 | 
						|
                                        </select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv2.minqp">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv2.maxqp">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv2.Iqp">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.encv2.Pqp">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col lp-align-center">
 | 
						|
                                        <bs-switch v-model="item.encv2.lowLatency" ></bs-switch>
 | 
						|
                                    </div>
 | 
						|
                                </div>
 | 
						|
                                <hr >
 | 
						|
                            </div>
 | 
						|
                        </div>
 | 
						|
                    </div>
 | 
						|
                    <div class="tab-pane fade" id="tab3" role="tabpanel">
 | 
						|
                        <div class="row">
 | 
						|
                            <div class="col-2 text-center">
 | 
						|
                                <cn>频道名称</cn>
 | 
						|
                                <en>channel name</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col-2 text-center">
 | 
						|
                                <cn>旋转</cn>
 | 
						|
                                <en>rotate</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col-2 text-center">
 | 
						|
                                <cn>左裁剪</cn>
 | 
						|
                                <en>left crop</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>右裁剪</cn>
 | 
						|
                                <en>right crop</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>上裁剪</cn>
 | 
						|
                                <en>top crop</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>下裁剪</cn>
 | 
						|
                                <en>bottom crop</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>全帧率去隔行</cn>
 | 
						|
                                <en>full framerate deinterlace</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>NTSC兼容</cn>
 | 
						|
                                <en>NTSC Compatible</en>
 | 
						|
                            </div>
 | 
						|
                        </div>
 | 
						|
                        <hr >
 | 
						|
                        <div class="row mt-1" v-for="(item,index) in handleVdoConf" :key="item.id">
 | 
						|
                            <div class="col-lg-12">
 | 
						|
                                <div class="row">
 | 
						|
                                    <div class="col-2 text-center">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.name">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col-2">
 | 
						|
                                        <select class="form-select" v-model="item.cap.rotate">
 | 
						|
                                            <option value="0">0</option>black
 | 
						|
                                            <option value="90">90</option>
 | 
						|
                                            <option value="180">180</option>
 | 
						|
                                            <option value="270">270</option>
 | 
						|
                                        </select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col-2">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.cap.crop.L">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.cap.crop.R">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.cap.crop.T">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.cap.crop.B">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col lp-align-center">
 | 
						|
                                        <bs-switch v-model="item.cap.deinterlace" v-if="item.type==='vi'"></bs-switch>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col lp-align-center">
 | 
						|
                                        <bs-switch v-model="item.cap.ntsc" v-if="item.type==='vi'"></bs-switch>
 | 
						|
                                    </div>
 | 
						|
                                </div>
 | 
						|
                                <hr >
 | 
						|
                            </div>
 | 
						|
                        </div>
 | 
						|
                    </div>
 | 
						|
                    <div class="tab-pane fade" id="tab4" role="tabpanel">
 | 
						|
                        <div class="row">
 | 
						|
                            <div class="col-2 text-center">
 | 
						|
                                <cn>频道名称</cn>
 | 
						|
                                <en>channel name</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>编码格式</cn>
 | 
						|
                                <en>codec</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>音源</cn>
 | 
						|
                                <en>source</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>增益</cn>
 | 
						|
                                <en>gain</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>采样率</cn>
 | 
						|
                                <en>samplerate</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>声道</cn>
 | 
						|
                                <en>channels</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>码率(kb/s)</cn>
 | 
						|
                                <en>bitrate(kb/s)</en>
 | 
						|
                            </div>
 | 
						|
                            <div v-if="Object.keys(hardwareConf).length > 0 && hardwareConf.model==='ENC8'" class="col text-center">
 | 
						|
                                <cn>音轨</cn>
 | 
						|
                                <en>audio track</en>
 | 
						|
                            </div>
 | 
						|
                        </div>
 | 
						|
                        <hr >
 | 
						|
                        <div class="row mt-1" v-for="(item,index) in handleAdoConf" :key="item.id">
 | 
						|
                            <div class="col-lg-12">
 | 
						|
                                <div class="row">
 | 
						|
                                    <div class="col-2 text-center">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.name">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <select class="form-select" v-model="item.enca.codec">
 | 
						|
                                            <option value="aac">AAC</option>
 | 
						|
                                            <option value="pcma">PCMA</option>
 | 
						|
                                            <option value="mp2">MPEG2</option>
 | 
						|
                                            <option value="mp3">MP3</option>
 | 
						|
                                            <option value="close" cn="关闭" en="close" v-language-option></option>
 | 
						|
                                        </select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <select class="form-select" v-model="item.enca.audioSrc">
 | 
						|
                                            <option v-if="Object.keys(hardwareConf).length > 0 && hardwareConf.function.line" value="line">Line</option>
 | 
						|
                                            <option v-for="(item,index) in defaultConf" :key="index" :value="item.id">{{item.name}}</option>
 | 
						|
                                        </select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <select class="form-select" v-model="item.enca.gain">
 | 
						|
                                            <option value="24">+24dB</option>
 | 
						|
                                            <option value="18">+18dB</option>
 | 
						|
                                            <option value="12">+12dB</option>
 | 
						|
                                            <option value="6">+6dB</option>
 | 
						|
                                            <option value="0">+0dB</option>
 | 
						|
                                            <option value="-6">-6dB</option>
 | 
						|
                                            <option value="-12">-12dB</option>
 | 
						|
                                            <option value="-18">-18dB</option>
 | 
						|
                                            <option value="-24">-24dB</option>
 | 
						|
                                        </select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <select class="form-select" v-model="item.enca.samplerate">
 | 
						|
                                            <option value="-1">auto</option>
 | 
						|
                                            <option value="16000">16K</option>
 | 
						|
                                            <option value="32000">32K</option>
 | 
						|
                                            <option value="44100">44.1K</option>
 | 
						|
                                            <option value="48000">48K</option>
 | 
						|
                                        </select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <select class="form-select" v-model="item.enca.channels">
 | 
						|
                                            <option cn="单声道" en="mono" value="1" v-language-option></option>
 | 
						|
                                            <option cn="立体声" en="stereo" value="2" v-language-option></option>
 | 
						|
                                        </select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.enca.bitrate">
 | 
						|
                                    </div>
 | 
						|
                                    <div v-if="Object.keys(hardwareConf).length > 0 && hardwareConf.model==='ENC8'" class="col">
 | 
						|
                                        <select v-if="item.enca.audioTrack" class="form-select" v-model.number="item.enca.audioTrack">
 | 
						|
                                            <option cn="源-Line" en="source-line" value="1" v-language-option></option>
 | 
						|
                                            <option cn="源-Hdmi" en="source-hdmi" value="2" v-language-option></option>
 | 
						|
                                        </select>
 | 
						|
                                    </div>
 | 
						|
                                </div>
 | 
						|
                                <hr >
 | 
						|
                            </div>
 | 
						|
                        </div>
 | 
						|
                    </div>
 | 
						|
                    <div class="tab-pane fade" id="tab5" role="tabpanel">
 | 
						|
                        <div class="row">
 | 
						|
                            <div class="col-2 text-center">
 | 
						|
                                <cn>频道名称</cn>
 | 
						|
                                <en>channel name</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col-3 text-center">
 | 
						|
                                <cn>流地址</cn>
 | 
						|
                                <en>stream url</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>帧率</cn>
 | 
						|
                                <en>framerate</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>缓冲模式</cn>
 | 
						|
                                <en>buffer mode</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>缓冲时间</cn>
 | 
						|
                                <en>buffer time</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>协议</cn>
 | 
						|
                                <en>protocol</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>视频解码</cn>
 | 
						|
                                <en>video decode</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>音频解码</cn>
 | 
						|
                                <en>audio decode</en>
 | 
						|
                            </div>
 | 
						|
                            <div class="col text-center">
 | 
						|
                                <cn>开关</cn>
 | 
						|
                                <en>enable</en>
 | 
						|
                            </div>
 | 
						|
                        </div>
 | 
						|
                        <hr >
 | 
						|
                        <div class="row mt-1" v-for="(item,index) in handleNetConf" :key="item.id">
 | 
						|
                            <div class="col-lg-12">
 | 
						|
                                <div class="row">
 | 
						|
                                    <div class="col-2 text-center">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.name">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col-3">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.net.path">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.net.framerate">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <select class="form-select" v-model="item.net.bufferMode">
 | 
						|
                                            <option value="0" cn="一般" en="Normal" v-language-option></option>
 | 
						|
                                            <option value="1" cn="实时" en="NoBuffer" v-language-option></option>
 | 
						|
                                            <option value="2" cn="缓冲" en="Buffer" v-language-option></option>
 | 
						|
                                            <option value="3" cn="帧同步" en="Sync" v-language-option></option>
 | 
						|
                                        </select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <input type="text" class="form-control" v-model.trim.lazy="item.net.minDelay">
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col">
 | 
						|
                                        <select class="form-select" v-model="item.net.protocol">
 | 
						|
                                            <option value="udp">UDP</option>
 | 
						|
                                            <option value="tcp">TCP</option>
 | 
						|
                                        </select>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col lp-align-center">
 | 
						|
                                        <bs-switch v-model="item.net.decodeV"></bs-switch>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col lp-align-center">
 | 
						|
                                        <bs-switch v-model="item.net.decodeA"></bs-switch>
 | 
						|
                                    </div>
 | 
						|
                                    <div class="col lp-align-center">
 | 
						|
                                        <bs-switch v-model="item.enable"></bs-switch>
 | 
						|
                                    </div>
 | 
						|
                                </div>
 | 
						|
                                <hr >
 | 
						|
                            </div>
 | 
						|
                        </div>
 | 
						|
                    </div>
 | 
						|
                    
 | 
						|
                    <div class="row mt-3">
 | 
						|
                        <div class="col-lg-12 text-center">
 | 
						|
                            <button type="button" class="btn btn-primary border-3 px-5" @click="saveDefaultConf">
 | 
						|
                                <cn>保存</cn>
 | 
						|
                                <en>Save</en>
 | 
						|
                            </button>
 | 
						|
                        </div>
 | 
						|
                    </div>
 | 
						|
                </div>
 | 
						|
            </div>
 | 
						|
        </div>
 | 
						|
    </main>
 | 
						|
</div>
 | 
						|
<?php include ("./public/foot.inc") ?>
 | 
						|
<script type="module">
 | 
						|
    
 | 
						|
    import { extend,deepCopy,confirm } from "./assets/js/lp.utils.js";
 | 
						|
    import { useDefaultConf,useHardwareConf } from "./assets/js/vue.hooks.js";
 | 
						|
    import { ignoreCustomElementPlugin,filterKeywordPlugin,bootstrapSwitchComponent,multipleSelectComponent,languageOptionDirective } from "./assets/js/vue.helper.js"
 | 
						|
    import vue from "./assets/js/vue.build.js";
 | 
						|
    const {createApp,reactive,watch,toRefs,computed,onMounted} = vue;
 | 
						|
 | 
						|
    const app = createApp({
 | 
						|
        directives:{
 | 
						|
            "language-option": languageOptionDirective
 | 
						|
        },
 | 
						|
        components:{
 | 
						|
            "bs-switch" : bootstrapSwitchComponent,
 | 
						|
            "multiple-select": multipleSelectComponent
 | 
						|
        },
 | 
						|
        setup(props,context) {
 | 
						|
            
 | 
						|
            const { defaultConf,updateDefaultConf } = useDefaultConf();
 | 
						|
            const { hardwareConf } = useHardwareConf();
 | 
						|
            let globalConf = reactive({});
 | 
						|
 | 
						|
            const unwatch = watch(defaultConf, (value) => {
 | 
						|
                for (let i = 0; i < defaultConf.length; i++) {
 | 
						|
                    if (defaultConf[i].type === "net" ) {
 | 
						|
                        if(!defaultConf[i].hasOwnProperty("cap")) {
 | 
						|
                            defaultConf[i].cap = {
 | 
						|
                                rotate: 0,
 | 
						|
                                crop: {
 | 
						|
                                    B: 0,
 | 
						|
                                    L: 0,
 | 
						|
                                    R: 0,
 | 
						|
                                    T: 0
 | 
						|
                                }
 | 
						|
                            }
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                }
 | 
						|
                Object.assign(globalConf, deepCopy(defaultConf[0]));
 | 
						|
                globalConf.enca.audioSrc = "source";
 | 
						|
                unwatch();
 | 
						|
            });
 | 
						|
            
 | 
						|
            const handleEncConf = computed(()=>{
 | 
						|
                return defaultConf.filter((item,index)=>{
 | 
						|
                    return !!((item.type === 'net' && item.net.decodeV) || (item.type !== 'net' && item.encv !== undefined));
 | 
						|
                })
 | 
						|
            })
 | 
						|
            
 | 
						|
            const handleAdvConf = computed(()=>{
 | 
						|
                return defaultConf.filter((item,index)=>{
 | 
						|
                    return !!(item.enable && item.type !== "ndi");
 | 
						|
                })
 | 
						|
            })
 | 
						|
            
 | 
						|
            const handleVdoConf = computed(()=>{
 | 
						|
                return defaultConf.filter((item,index)=>{
 | 
						|
                    return item.type === 'net' || item.type === 'vi';
 | 
						|
                })
 | 
						|
            })
 | 
						|
            
 | 
						|
            const handleAdoConf = computed(()=>{
 | 
						|
                return defaultConf.filter((item,index)=>{
 | 
						|
                    return !!((item.type === 'net' && item.net.decodeA) || (item.type !== 'net' && item.enca !== undefined));
 | 
						|
                })
 | 
						|
            })
 | 
						|
 | 
						|
            const handleNetConf = computed(()=>{
 | 
						|
                return defaultConf.filter((item,index)=>{
 | 
						|
                    return item.type === 'net';
 | 
						|
                })
 | 
						|
            })
 | 
						|
 | 
						|
            const saveGlobalConfByLocal = () => {
 | 
						|
                for ( let i = 0; i < defaultConf.length; i++ ) {
 | 
						|
                    if (defaultConf[i].encv === undefined || defaultConf[i].enca === undefined )
 | 
						|
                        continue;
 | 
						|
                    extend(defaultConf[i].encv, deepCopy(globalConf.encv));
 | 
						|
                    extend(defaultConf[i].encv2, deepCopy(globalConf.encv2));
 | 
						|
                    extend(defaultConf[i].enca, deepCopy(globalConf.enca));
 | 
						|
                    if(defaultConf[i].enca.audioSrc === "source")
 | 
						|
                        defaultConf[i].enca.audioSrc = defaultConf[i].id;
 | 
						|
                    if(defaultConf[i].type !== "vi" && defaultConf[i].enca.hasOwnProperty("audioTrack"))
 | 
						|
                        delete defaultConf[i].enca.audioTrack;
 | 
						|
                }
 | 
						|
                saveDefaultConf();
 | 
						|
            }
 | 
						|
            
 | 
						|
            const saveDefaultConf = () => {
 | 
						|
 | 
						|
                const maxENC = hardwareConf.capability.encode.maxPixel;
 | 
						|
                let sum=0;
 | 
						|
                for ( let i = 0; i < defaultConf.length; i++ ) {
 | 
						|
                    if(defaultConf[i].enable && defaultConf[i].encv !== undefined){
 | 
						|
                        if(defaultConf[i].encv.codec !== "close")
 | 
						|
                            sum+=defaultConf[i].encv.width*defaultConf[i].encv.height*defaultConf[i].encv.framerate;
 | 
						|
                        if(defaultConf[i].enable2 && defaultConf[i].encv2.codec !== "close"){
 | 
						|
                            sum+=defaultConf[i].encv2.width*defaultConf[i].encv2.height*defaultConf[i].encv2.framerate;
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                }
 | 
						|
 | 
						|
                if(maxENC > 0 && sum > maxENC) {
 | 
						|
                    confirm( {
 | 
						|
                        title: '<cn>警告</cn><en>Warning</en>',
 | 
						|
                        content: '<cn>超出编码性能上限,请调整编码参数!</cn><en>The limit of encode performance is exceeded. Please adjust the encode parameters!</en>',
 | 
						|
                        buttons: {
 | 
						|
                            ok: {
 | 
						|
                                text: "<cn>知道了</cn><en>I know</en>",
 | 
						|
                                btnClass: 'btn-primary',
 | 
						|
                                keys: [ 'enter' ],
 | 
						|
                                action: () => updateDefaultConf()
 | 
						|
                            }
 | 
						|
                        }
 | 
						|
                    } );
 | 
						|
                    return;
 | 
						|
                }
 | 
						|
                updateDefaultConf();
 | 
						|
            }
 | 
						|
            
 | 
						|
            return {globalConf,defaultConf,hardwareConf,
 | 
						|
                handleEncConf, handleAdvConf,handleVdoConf,handleAdoConf,
 | 
						|
                handleNetConf,saveGlobalConfByLocal,saveDefaultConf}
 | 
						|
        }
 | 
						|
    });
 | 
						|
    app.use(ignoreCustomElementPlugin);
 | 
						|
    app.use(filterKeywordPlugin);
 | 
						|
    app.mount('#app');
 | 
						|
</script>
 | 
						|
</body>
 | 
						|
</html>
 |