UI: Improve/refactor autoconfig/settings service UI
Makes it so that services can have custom handling on a per-service basis. The bottom part of the service pane is now a stacked widget which can now be customized for different types of services (particularly OAuth services).
This commit is contained in:
parent
dcf48e8ffc
commit
24bcfacea5
@ -134,6 +134,7 @@ set(obs_SOURCES
|
|||||||
window-basic-auto-config.cpp
|
window-basic-auto-config.cpp
|
||||||
window-basic-main-outputs.cpp
|
window-basic-main-outputs.cpp
|
||||||
window-basic-source-select.cpp
|
window-basic-source-select.cpp
|
||||||
|
window-basic-settings-stream.cpp
|
||||||
window-basic-auto-config-test.cpp
|
window-basic-auto-config-test.cpp
|
||||||
window-basic-main-scene-collections.cpp
|
window-basic-main-scene-collections.cpp
|
||||||
window-basic-main-transitions.cpp
|
window-basic-main-transitions.cpp
|
||||||
|
@ -127,7 +127,7 @@ Basic.AutoConfig.StreamPage="Stream Information"
|
|||||||
Basic.AutoConfig.StreamPage.SubTitle="Please enter your stream information"
|
Basic.AutoConfig.StreamPage.SubTitle="Please enter your stream information"
|
||||||
Basic.AutoConfig.StreamPage.Service="Service"
|
Basic.AutoConfig.StreamPage.Service="Service"
|
||||||
Basic.AutoConfig.StreamPage.Service.ShowAll="Show All..."
|
Basic.AutoConfig.StreamPage.Service.ShowAll="Show All..."
|
||||||
Basic.AutoConfig.StreamPage.Service.Custom="Custom"
|
Basic.AutoConfig.StreamPage.Service.Custom="Custom..."
|
||||||
Basic.AutoConfig.StreamPage.Server="Server"
|
Basic.AutoConfig.StreamPage.Server="Server"
|
||||||
Basic.AutoConfig.StreamPage.StreamKey="Stream Key"
|
Basic.AutoConfig.StreamPage.StreamKey="Stream Key"
|
||||||
Basic.AutoConfig.StreamPage.StreamKey.LinkToSite="(Link)"
|
Basic.AutoConfig.StreamPage.StreamKey.LinkToSite="(Link)"
|
||||||
|
@ -13,14 +13,54 @@
|
|||||||
<property name="windowTitle">
|
<property name="windowTitle">
|
||||||
<string notr="true"/>
|
<string notr="true"/>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QFormLayout" name="formLayout">
|
<layout class="QVBoxLayout" name="verticalLayout">
|
||||||
|
<property name="spacing">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="leftMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="topMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="rightMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="bottomMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<item>
|
||||||
|
<widget class="QWidget" name="widget" native="true">
|
||||||
|
<property name="sizePolicy">
|
||||||
|
<sizepolicy hsizetype="Preferred" vsizetype="Maximum">
|
||||||
|
<horstretch>0</horstretch>
|
||||||
|
<verstretch>0</verstretch>
|
||||||
|
</sizepolicy>
|
||||||
|
</property>
|
||||||
|
<layout class="QFormLayout" name="topLayout">
|
||||||
<property name="fieldGrowthPolicy">
|
<property name="fieldGrowthPolicy">
|
||||||
<enum>QFormLayout::ExpandingFieldsGrow</enum>
|
<enum>QFormLayout::ExpandingFieldsGrow</enum>
|
||||||
</property>
|
</property>
|
||||||
<property name="labelAlignment">
|
<property name="labelAlignment">
|
||||||
<set>Qt::AlignRight|Qt::AlignTop|Qt::AlignTrailing</set>
|
<set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
|
||||||
</property>
|
</property>
|
||||||
<item row="0" column="0">
|
<item row="0" column="0">
|
||||||
|
<spacer name="horizontalSpacer_6">
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Horizontal</enum>
|
||||||
|
</property>
|
||||||
|
<property name="sizeType">
|
||||||
|
<enum>QSizePolicy::Fixed</enum>
|
||||||
|
</property>
|
||||||
|
<property name="sizeHint" stdset="0">
|
||||||
|
<size>
|
||||||
|
<width>87</width>
|
||||||
|
<height>0</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
</spacer>
|
||||||
|
</item>
|
||||||
|
<item row="1" column="0">
|
||||||
<widget class="QLabel" name="serviceLabel">
|
<widget class="QLabel" name="serviceLabel">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Basic.AutoConfig.StreamPage.Service</string>
|
<string>Basic.AutoConfig.StreamPage.Service</string>
|
||||||
@ -30,17 +70,33 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="0" column="1">
|
<item row="1" column="1">
|
||||||
<widget class="QComboBox" name="service"/>
|
<widget class="QComboBox" name="service"/>
|
||||||
</item>
|
</item>
|
||||||
<item row="1" column="0">
|
</layout>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QStackedWidget" name="stackedWidget">
|
||||||
|
<property name="currentIndex">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<widget class="QWidget" name="streamkeyPage">
|
||||||
|
<layout class="QFormLayout" name="streamkeyPageLayout">
|
||||||
|
<property name="fieldGrowthPolicy">
|
||||||
|
<enum>QFormLayout::ExpandingFieldsGrow</enum>
|
||||||
|
</property>
|
||||||
|
<property name="labelAlignment">
|
||||||
|
<set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
|
||||||
|
</property>
|
||||||
|
<item row="0" column="0">
|
||||||
<widget class="QLabel" name="serverLabel">
|
<widget class="QLabel" name="serverLabel">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Basic.AutoConfig.StreamPage.Server</string>
|
<string>Basic.AutoConfig.StreamPage.Server</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="1" column="1">
|
<item row="0" column="1">
|
||||||
<widget class="QStackedWidget" name="serverStackedWidget">
|
<widget class="QStackedWidget" name="serverStackedWidget">
|
||||||
<property name="currentIndex">
|
<property name="currentIndex">
|
||||||
<number>0</number>
|
<number>0</number>
|
||||||
@ -85,7 +141,7 @@
|
|||||||
</widget>
|
</widget>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="2" column="0">
|
<item row="1" column="0">
|
||||||
<widget class="QLabel" name="streamKeyLabel">
|
<widget class="QLabel" name="streamKeyLabel">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Basic.AutoConfig.StreamPage.StreamKey</string>
|
<string>Basic.AutoConfig.StreamPage.StreamKey</string>
|
||||||
@ -98,8 +154,21 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="2" column="1">
|
<item row="1" column="1">
|
||||||
<layout class="QHBoxLayout" name="horizontalLayout">
|
<widget class="QWidget" name="streamKeyWidget" native="true">
|
||||||
|
<layout class="QHBoxLayout" name="horizontalLayout_4">
|
||||||
|
<property name="leftMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="topMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="rightMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="bottomMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QLineEdit" name="key">
|
<widget class="QLineEdit" name="key">
|
||||||
<property name="inputMask">
|
<property name="inputMask">
|
||||||
@ -121,8 +190,9 @@
|
|||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="3" column="0">
|
<item row="2" column="0">
|
||||||
<widget class="QLabel" name="bitrateLabel">
|
<widget class="QLabel" name="bitrateLabel">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Basic.Settings.Output.VideoBitrate</string>
|
<string>Basic.Settings.Output.VideoBitrate</string>
|
||||||
@ -132,7 +202,7 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="3" column="1">
|
<item row="2" column="1">
|
||||||
<widget class="QSpinBox" name="bitrate">
|
<widget class="QSpinBox" name="bitrate">
|
||||||
<property name="suffix">
|
<property name="suffix">
|
||||||
<string notr="true"/>
|
<string notr="true"/>
|
||||||
@ -148,7 +218,7 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="4" column="1">
|
<item row="3" column="1">
|
||||||
<widget class="QCheckBox" name="preferHardware">
|
<widget class="QCheckBox" name="preferHardware">
|
||||||
<property name="toolTip">
|
<property name="toolTip">
|
||||||
<string>Basic.AutoConfig.StreamPage.PreferHardwareEncoding.ToolTip</string>
|
<string>Basic.AutoConfig.StreamPage.PreferHardwareEncoding.ToolTip</string>
|
||||||
@ -161,8 +231,8 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="5" column="0">
|
<item row="4" column="0">
|
||||||
<spacer name="horizontalSpacer">
|
<spacer name="horizontalSpacer_5">
|
||||||
<property name="orientation">
|
<property name="orientation">
|
||||||
<enum>Qt::Horizontal</enum>
|
<enum>Qt::Horizontal</enum>
|
||||||
</property>
|
</property>
|
||||||
@ -171,13 +241,13 @@
|
|||||||
</property>
|
</property>
|
||||||
<property name="sizeHint" stdset="0">
|
<property name="sizeHint" stdset="0">
|
||||||
<size>
|
<size>
|
||||||
<width>90</width>
|
<width>87</width>
|
||||||
<height>20</height>
|
<height>17</height>
|
||||||
</size>
|
</size>
|
||||||
</property>
|
</property>
|
||||||
</spacer>
|
</spacer>
|
||||||
</item>
|
</item>
|
||||||
<item row="5" column="1">
|
<item row="4" column="1">
|
||||||
<widget class="QCheckBox" name="doBandwidthTest">
|
<widget class="QCheckBox" name="doBandwidthTest">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Basic.AutoConfig.StreamPage.PerformBandwidthTest</string>
|
<string>Basic.AutoConfig.StreamPage.PerformBandwidthTest</string>
|
||||||
@ -187,7 +257,7 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="6" column="1">
|
<item row="5" column="1">
|
||||||
<widget class="QGroupBox" name="region">
|
<widget class="QGroupBox" name="region">
|
||||||
<property name="title">
|
<property name="title">
|
||||||
<string>BandwidthTest.Region</string>
|
<string>BandwidthTest.Region</string>
|
||||||
@ -226,19 +296,10 @@
|
|||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
<tabstops>
|
</widget>
|
||||||
<tabstop>service</tabstop>
|
</item>
|
||||||
<tabstop>server</tabstop>
|
</layout>
|
||||||
<tabstop>customServer</tabstop>
|
</widget>
|
||||||
<tabstop>key</tabstop>
|
|
||||||
<tabstop>show</tabstop>
|
|
||||||
<tabstop>preferHardware</tabstop>
|
|
||||||
<tabstop>doBandwidthTest</tabstop>
|
|
||||||
<tabstop>regionUS</tabstop>
|
|
||||||
<tabstop>regionEU</tabstop>
|
|
||||||
<tabstop>regionAsia</tabstop>
|
|
||||||
<tabstop>regionOther</tabstop>
|
|
||||||
</tabstops>
|
|
||||||
<resources/>
|
<resources/>
|
||||||
<connections/>
|
<connections/>
|
||||||
</ui>
|
</ui>
|
||||||
|
@ -145,8 +145,8 @@
|
|||||||
<rect>
|
<rect>
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>804</width>
|
<width>801</width>
|
||||||
<height>1072</height>
|
<height>836</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_19">
|
<layout class="QVBoxLayout" name="verticalLayout_19">
|
||||||
@ -686,27 +686,6 @@
|
|||||||
<number>0</number>
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QWidget" name="streamContainer" native="true">
|
|
||||||
<property name="sizePolicy">
|
|
||||||
<sizepolicy hsizetype="Preferred" vsizetype="Minimum">
|
|
||||||
<horstretch>0</horstretch>
|
|
||||||
<verstretch>0</verstretch>
|
|
||||||
</sizepolicy>
|
|
||||||
</property>
|
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_6">
|
|
||||||
<property name="leftMargin">
|
|
||||||
<number>0</number>
|
|
||||||
</property>
|
|
||||||
<property name="topMargin">
|
|
||||||
<number>0</number>
|
|
||||||
</property>
|
|
||||||
<property name="rightMargin">
|
|
||||||
<number>0</number>
|
|
||||||
</property>
|
|
||||||
<property name="bottomMargin">
|
|
||||||
<number>0</number>
|
|
||||||
</property>
|
|
||||||
<item alignment="Qt::AlignTop">
|
|
||||||
<widget class="QWidget" name="widget_5" native="true">
|
<widget class="QWidget" name="widget_5" native="true">
|
||||||
<property name="sizePolicy">
|
<property name="sizePolicy">
|
||||||
<sizepolicy hsizetype="Preferred" vsizetype="Maximum">
|
<sizepolicy hsizetype="Preferred" vsizetype="Maximum">
|
||||||
@ -714,7 +693,79 @@
|
|||||||
<verstretch>0</verstretch>
|
<verstretch>0</verstretch>
|
||||||
</sizepolicy>
|
</sizepolicy>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_7">
|
<layout class="QFormLayout" name="topStreamLayout">
|
||||||
|
<property name="fieldGrowthPolicy">
|
||||||
|
<enum>QFormLayout::AllNonFixedFieldsGrow</enum>
|
||||||
|
</property>
|
||||||
|
<property name="labelAlignment">
|
||||||
|
<set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
|
||||||
|
</property>
|
||||||
|
<item row="2" column="0">
|
||||||
|
<widget class="QLabel" name="serviceLabel">
|
||||||
|
<property name="text">
|
||||||
|
<string>Basic.AutoConfig.StreamPage.Service</string>
|
||||||
|
</property>
|
||||||
|
<property name="buddy">
|
||||||
|
<cstring>service</cstring>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="2" column="1">
|
||||||
|
<widget class="QComboBox" name="service">
|
||||||
|
<property name="maxVisibleItems">
|
||||||
|
<number>20</number>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="1" column="0">
|
||||||
|
<spacer name="horizontalSpacer_17">
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Horizontal</enum>
|
||||||
|
</property>
|
||||||
|
<property name="sizeHint" stdset="0">
|
||||||
|
<size>
|
||||||
|
<width>170</width>
|
||||||
|
<height>0</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
</spacer>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QStackedWidget" name="streamStackWidget">
|
||||||
|
<property name="sizePolicy">
|
||||||
|
<sizepolicy hsizetype="Expanding" vsizetype="Expanding">
|
||||||
|
<horstretch>0</horstretch>
|
||||||
|
<verstretch>0</verstretch>
|
||||||
|
</sizepolicy>
|
||||||
|
</property>
|
||||||
|
<property name="currentIndex">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<widget class="QWidget" name="streamKeyPage">
|
||||||
|
<layout class="QFormLayout" name="streamkeyPageLayout">
|
||||||
|
<property name="fieldGrowthPolicy">
|
||||||
|
<enum>QFormLayout::AllNonFixedFieldsGrow</enum>
|
||||||
|
</property>
|
||||||
|
<property name="labelAlignment">
|
||||||
|
<set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
|
||||||
|
</property>
|
||||||
|
<item row="0" column="0">
|
||||||
|
<widget class="QLabel" name="serverLabel">
|
||||||
|
<property name="text">
|
||||||
|
<string>Basic.AutoConfig.StreamPage.Server</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="0" column="1">
|
||||||
|
<widget class="QStackedWidget" name="serverStackedWidget">
|
||||||
|
<property name="currentIndex">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<widget class="QWidget" name="servicePage">
|
||||||
|
<layout class="QHBoxLayout" name="horizontalLayout_21">
|
||||||
<property name="leftMargin">
|
<property name="leftMargin">
|
||||||
<number>0</number>
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
@ -728,48 +779,98 @@
|
|||||||
<number>0</number>
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QWidget" name="widget_6" native="true">
|
<widget class="QComboBox" name="server"/>
|
||||||
<layout class="QFormLayout" name="formLayout_8">
|
</item>
|
||||||
<property name="fieldGrowthPolicy">
|
</layout>
|
||||||
<enum>QFormLayout::AllNonFixedFieldsGrow</enum>
|
</widget>
|
||||||
|
<widget class="QWidget" name="customPage">
|
||||||
|
<layout class="QHBoxLayout" name="horizontalLayout_22">
|
||||||
|
<property name="leftMargin">
|
||||||
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
<item row="0" column="0">
|
<property name="topMargin">
|
||||||
<widget class="QLabel" name="label_21">
|
<number>0</number>
|
||||||
<property name="minimumSize">
|
|
||||||
<size>
|
|
||||||
<width>170</width>
|
|
||||||
<height>0</height>
|
|
||||||
</size>
|
|
||||||
</property>
|
</property>
|
||||||
|
<property name="rightMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="bottomMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<item>
|
||||||
|
<widget class="QLineEdit" name="customServer"/>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</widget>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="1" column="0">
|
||||||
|
<widget class="QLabel" name="streamKeyLabel">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Basic.Settings.Stream.StreamType</string>
|
<string>Basic.AutoConfig.StreamPage.StreamKey</string>
|
||||||
</property>
|
</property>
|
||||||
<property name="alignment">
|
<property name="openExternalLinks">
|
||||||
<set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
|
<bool>true</bool>
|
||||||
</property>
|
</property>
|
||||||
<property name="buddy">
|
<property name="buddy">
|
||||||
<cstring>streamType</cstring>
|
<cstring>key</cstring>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="0" column="1">
|
<item row="1" column="1">
|
||||||
<widget class="QComboBox" name="streamType"/>
|
<widget class="QWidget" name="streamKeyWidget" native="true">
|
||||||
</item>
|
<layout class="QHBoxLayout" name="horizontalLayout_11">
|
||||||
</layout>
|
<property name="leftMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="topMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="rightMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="bottomMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<item>
|
||||||
|
<widget class="QLineEdit" name="key">
|
||||||
|
<property name="inputMask">
|
||||||
|
<string notr="true"/>
|
||||||
|
</property>
|
||||||
|
<property name="text">
|
||||||
|
<string notr="true"/>
|
||||||
|
</property>
|
||||||
|
<property name="echoMode">
|
||||||
|
<enum>QLineEdit::Password</enum>
|
||||||
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<widget class="Line" name="line">
|
<widget class="QPushButton" name="show">
|
||||||
<property name="orientation">
|
<property name="text">
|
||||||
<enum>Qt::Horizontal</enum>
|
<string>Show</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
<item row="2" column="0">
|
||||||
|
<spacer name="horizontalSpacer_18">
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Horizontal</enum>
|
||||||
|
</property>
|
||||||
|
<property name="sizeHint" stdset="0">
|
||||||
|
<size>
|
||||||
|
<width>170</width>
|
||||||
|
<height>8</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
</spacer>
|
||||||
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
@ -797,8 +898,8 @@
|
|||||||
<rect>
|
<rect>
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>813</width>
|
<width>818</width>
|
||||||
<height>770</height>
|
<height>697</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_21">
|
<layout class="QVBoxLayout" name="verticalLayout_21">
|
||||||
@ -3913,7 +4014,7 @@
|
|||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>594</width>
|
<width>594</width>
|
||||||
<height>807</height>
|
<height>833</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_23">
|
<layout class="QVBoxLayout" name="verticalLayout_23">
|
||||||
@ -4751,7 +4852,6 @@
|
|||||||
</widget>
|
</widget>
|
||||||
<tabstops>
|
<tabstops>
|
||||||
<tabstop>listWidget</tabstop>
|
<tabstop>listWidget</tabstop>
|
||||||
<tabstop>streamType</tabstop>
|
|
||||||
<tabstop>outputMode</tabstop>
|
<tabstop>outputMode</tabstop>
|
||||||
<tabstop>simpleOutputVBitrate</tabstop>
|
<tabstop>simpleOutputVBitrate</tabstop>
|
||||||
<tabstop>simpleOutputABitrate</tabstop>
|
<tabstop>simpleOutputABitrate</tabstop>
|
||||||
@ -4939,8 +5039,8 @@
|
|||||||
<y>16</y>
|
<y>16</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>250</x>
|
<x>401</x>
|
||||||
<y>39</y>
|
<y>64</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
</connection>
|
</connection>
|
||||||
@ -4951,12 +5051,12 @@
|
|||||||
<slot>setVisible(bool)</slot>
|
<slot>setVisible(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>250</x>
|
<x>251</x>
|
||||||
<y>39</y>
|
<y>64</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>250</x>
|
<x>251</x>
|
||||||
<y>39</y>
|
<y>64</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
</connection>
|
</connection>
|
||||||
@ -4967,12 +5067,12 @@
|
|||||||
<slot>setVisible(bool)</slot>
|
<slot>setVisible(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>250</x>
|
<x>251</x>
|
||||||
<y>39</y>
|
<y>64</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>250</x>
|
<x>251</x>
|
||||||
<y>39</y>
|
<y>64</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
</connection>
|
</connection>
|
||||||
@ -4983,12 +5083,12 @@
|
|||||||
<slot>setVisible(bool)</slot>
|
<slot>setVisible(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>250</x>
|
<x>251</x>
|
||||||
<y>39</y>
|
<y>64</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>250</x>
|
<x>251</x>
|
||||||
<y>39</y>
|
<y>64</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
</connection>
|
</connection>
|
||||||
@ -4999,12 +5099,12 @@
|
|||||||
<slot>setVisible(bool)</slot>
|
<slot>setVisible(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>250</x>
|
<x>251</x>
|
||||||
<y>39</y>
|
<y>64</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>250</x>
|
<x>251</x>
|
||||||
<y>39</y>
|
<y>64</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
</connection>
|
</connection>
|
||||||
@ -5015,12 +5115,12 @@
|
|||||||
<slot>setCurrentIndex(int)</slot>
|
<slot>setCurrentIndex(int)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>232</x>
|
<x>260</x>
|
||||||
<y>41</y>
|
<y>73</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>241</x>
|
<x>242</x>
|
||||||
<y>30</y>
|
<y>85</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
</connection>
|
</connection>
|
||||||
@ -5031,12 +5131,12 @@
|
|||||||
<slot>setEnabled(bool)</slot>
|
<slot>setEnabled(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>259</x>
|
<x>260</x>
|
||||||
<y>60</y>
|
<y>85</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>228</x>
|
<x>229</x>
|
||||||
<y>50</y>
|
<y>85</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
</connection>
|
</connection>
|
||||||
@ -5047,12 +5147,12 @@
|
|||||||
<slot>setEnabled(bool)</slot>
|
<slot>setEnabled(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>259</x>
|
<x>260</x>
|
||||||
<y>39</y>
|
<y>64</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>228</x>
|
<x>229</x>
|
||||||
<y>29</y>
|
<y>64</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
</connection>
|
</connection>
|
||||||
@ -5063,12 +5163,12 @@
|
|||||||
<slot>setEnabled(bool)</slot>
|
<slot>setEnabled(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>168</x>
|
<x>260</x>
|
||||||
<y>56</y>
|
<y>85</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>228</x>
|
<x>229</x>
|
||||||
<y>50</y>
|
<y>85</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
</connection>
|
</connection>
|
||||||
@ -5079,12 +5179,12 @@
|
|||||||
<slot>setCurrentIndex(int)</slot>
|
<slot>setCurrentIndex(int)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>250</x>
|
<x>260</x>
|
||||||
<y>50</y>
|
<y>85</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>250</x>
|
<x>260</x>
|
||||||
<y>52</y>
|
<y>85</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
</connection>
|
</connection>
|
||||||
@ -5095,12 +5195,12 @@
|
|||||||
<slot>setVisible(bool)</slot>
|
<slot>setVisible(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>250</x>
|
<x>251</x>
|
||||||
<y>39</y>
|
<y>64</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>250</x>
|
<x>251</x>
|
||||||
<y>39</y>
|
<y>64</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
</connection>
|
</connection>
|
||||||
@ -5111,11 +5211,11 @@
|
|||||||
<slot>setEnabled(bool)</slot>
|
<slot>setEnabled(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>579</y>
|
<y>579</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>602</y>
|
<y>602</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
@ -5127,11 +5227,11 @@
|
|||||||
<slot>setEnabled(bool)</slot>
|
<slot>setEnabled(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>579</y>
|
<y>579</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>625</y>
|
<y>625</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
@ -5159,7 +5259,7 @@
|
|||||||
<slot>setEnabled(bool)</slot>
|
<slot>setEnabled(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>340</y>
|
<y>340</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
@ -5175,11 +5275,11 @@
|
|||||||
<slot>setEnabled(bool)</slot>
|
<slot>setEnabled(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>340</y>
|
<y>340</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>366</y>
|
<y>366</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
@ -5191,11 +5291,11 @@
|
|||||||
<slot>setEnabled(bool)</slot>
|
<slot>setEnabled(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>340</y>
|
<y>340</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>389</y>
|
<y>389</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
@ -5207,11 +5307,11 @@
|
|||||||
<slot>setEnabled(bool)</slot>
|
<slot>setEnabled(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>340</y>
|
<y>340</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>412</y>
|
<y>412</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
@ -5223,11 +5323,11 @@
|
|||||||
<slot>setEnabled(bool)</slot>
|
<slot>setEnabled(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>340</y>
|
<y>340</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>435</y>
|
<y>435</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
@ -5239,11 +5339,11 @@
|
|||||||
<slot>setEnabled(bool)</slot>
|
<slot>setEnabled(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>222</y>
|
<y>222</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>245</y>
|
<y>245</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
@ -5255,11 +5355,11 @@
|
|||||||
<slot>setEnabled(bool)</slot>
|
<slot>setEnabled(bool)</slot>
|
||||||
<hints>
|
<hints>
|
||||||
<hint type="sourcelabel">
|
<hint type="sourcelabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>268</y>
|
<y>268</y>
|
||||||
</hint>
|
</hint>
|
||||||
<hint type="destinationlabel">
|
<hint type="destinationlabel">
|
||||||
<x>950</x>
|
<x>933</x>
|
||||||
<y>291</y>
|
<y>291</y>
|
||||||
</hint>
|
</hint>
|
||||||
</hints>
|
</hints>
|
||||||
|
@ -223,6 +223,16 @@ AutoConfigStreamPage::AutoConfigStreamPage(QWidget *parent)
|
|||||||
ui->bitrateLabel->setVisible(false);
|
ui->bitrateLabel->setVisible(false);
|
||||||
ui->bitrate->setVisible(false);
|
ui->bitrate->setVisible(false);
|
||||||
|
|
||||||
|
int vertSpacing = ui->topLayout->verticalSpacing();
|
||||||
|
|
||||||
|
QMargins m = ui->topLayout->contentsMargins();
|
||||||
|
m.setBottom(vertSpacing / 2);
|
||||||
|
ui->topLayout->setContentsMargins(m);
|
||||||
|
|
||||||
|
m = ui->streamkeyPageLayout->contentsMargins();
|
||||||
|
m.setTop(vertSpacing / 2);
|
||||||
|
ui->streamkeyPageLayout->setContentsMargins(m);
|
||||||
|
|
||||||
setTitle(QTStr("Basic.AutoConfig.StreamPage"));
|
setTitle(QTStr("Basic.AutoConfig.StreamPage"));
|
||||||
setSubTitle(QTStr("Basic.AutoConfig.StreamPage.SubTitle"));
|
setSubTitle(QTStr("Basic.AutoConfig.StreamPage.SubTitle"));
|
||||||
|
|
||||||
@ -378,11 +388,11 @@ void AutoConfigStreamPage::ServiceChanged()
|
|||||||
if (service == "Twitch" && wiz->twitchAuto)
|
if (service == "Twitch" && wiz->twitchAuto)
|
||||||
regionBased = false;
|
regionBased = false;
|
||||||
|
|
||||||
ui->formLayout->removeWidget(ui->serverLabel);
|
ui->streamkeyPageLayout->removeWidget(ui->serverLabel);
|
||||||
ui->formLayout->removeWidget(ui->serverStackedWidget);
|
ui->streamkeyPageLayout->removeWidget(ui->serverStackedWidget);
|
||||||
|
|
||||||
if (custom) {
|
if (custom) {
|
||||||
ui->formLayout->insertRow(1, ui->serverLabel,
|
ui->streamkeyPageLayout->insertRow(1, ui->serverLabel,
|
||||||
ui->serverStackedWidget);
|
ui->serverStackedWidget);
|
||||||
|
|
||||||
ui->region->setVisible(false);
|
ui->region->setVisible(false);
|
||||||
@ -391,7 +401,7 @@ void AutoConfigStreamPage::ServiceChanged()
|
|||||||
ui->serverLabel->setVisible(true);
|
ui->serverLabel->setVisible(true);
|
||||||
} else {
|
} else {
|
||||||
if (!testBandwidth)
|
if (!testBandwidth)
|
||||||
ui->formLayout->insertRow(2, ui->serverLabel,
|
ui->streamkeyPageLayout->insertRow(2, ui->serverLabel,
|
||||||
ui->serverStackedWidget);
|
ui->serverStackedWidget);
|
||||||
|
|
||||||
ui->region->setVisible(regionBased && testBandwidth);
|
ui->region->setVisible(regionBased && testBandwidth);
|
||||||
@ -474,12 +484,6 @@ void AutoConfigStreamPage::LoadServices(bool showAll)
|
|||||||
for (QString &name : names)
|
for (QString &name : names)
|
||||||
ui->service->addItem(name);
|
ui->service->addItem(name);
|
||||||
|
|
||||||
if (!lastService.isEmpty()) {
|
|
||||||
int idx = ui->service->findText(lastService);
|
|
||||||
if (idx != -1)
|
|
||||||
ui->service->setCurrentIndex(idx);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!showAll) {
|
if (!showAll) {
|
||||||
ui->service->addItem(
|
ui->service->addItem(
|
||||||
QTStr("Basic.AutoConfig.StreamPage.Service.ShowAll"),
|
QTStr("Basic.AutoConfig.StreamPage.Service.ShowAll"),
|
||||||
@ -490,6 +494,12 @@ void AutoConfigStreamPage::LoadServices(bool showAll)
|
|||||||
QTStr("Basic.AutoConfig.StreamPage.Service.Custom"),
|
QTStr("Basic.AutoConfig.StreamPage.Service.Custom"),
|
||||||
QVariant((int)ListOpt::Custom));
|
QVariant((int)ListOpt::Custom));
|
||||||
|
|
||||||
|
if (!lastService.isEmpty()) {
|
||||||
|
int idx = ui->service->findText(lastService);
|
||||||
|
if (idx != -1)
|
||||||
|
ui->service->setCurrentIndex(idx);
|
||||||
|
}
|
||||||
|
|
||||||
obs_properties_destroy(props);
|
obs_properties_destroy(props);
|
||||||
|
|
||||||
ui->service->blockSignals(false);
|
ui->service->blockSignals(false);
|
||||||
@ -573,7 +583,7 @@ AutoConfig::AutoConfig(QWidget *parent)
|
|||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
setWizardStyle(QWizard::ModernStyle);
|
setWizardStyle(QWizard::ModernStyle);
|
||||||
#endif
|
#endif
|
||||||
AutoConfigStreamPage *streamPage = new AutoConfigStreamPage();
|
streamPage = new AutoConfigStreamPage();
|
||||||
|
|
||||||
setPage(StartPage, new AutoConfigStartPage());
|
setPage(StartPage, new AutoConfigStartPage());
|
||||||
setPage(VideoPage, new AutoConfigVideoPage());
|
setPage(VideoPage, new AutoConfigVideoPage());
|
||||||
@ -637,6 +647,7 @@ AutoConfig::AutoConfig(QWidget *parent)
|
|||||||
|
|
||||||
streamPage->UpdateServerList();
|
streamPage->UpdateServerList();
|
||||||
streamPage->UpdateKeyLink();
|
streamPage->UpdateKeyLink();
|
||||||
|
streamPage->lastService.clear();
|
||||||
|
|
||||||
if (!customServer) {
|
if (!customServer) {
|
||||||
QComboBox *serverList = streamPage->ui->server;
|
QComboBox *serverList = streamPage->ui->server;
|
||||||
|
@ -17,6 +17,8 @@ class Ui_AutoConfigVideoPage;
|
|||||||
class Ui_AutoConfigStreamPage;
|
class Ui_AutoConfigStreamPage;
|
||||||
class Ui_AutoConfigTestPage;
|
class Ui_AutoConfigTestPage;
|
||||||
|
|
||||||
|
class AutoConfigStreamPage;
|
||||||
|
|
||||||
class AutoConfig : public QWizard {
|
class AutoConfig : public QWizard {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
@ -60,6 +62,8 @@ class AutoConfig : public QWizard {
|
|||||||
|
|
||||||
static inline const char *GetEncoderId(Encoder enc);
|
static inline const char *GetEncoderId(Encoder enc);
|
||||||
|
|
||||||
|
AutoConfigStreamPage *streamPage = nullptr;
|
||||||
|
|
||||||
Service service = Service::Other;
|
Service service = Service::Other;
|
||||||
Quality recordingQuality = Quality::Stream;
|
Quality recordingQuality = Quality::Stream;
|
||||||
Encoder recordingEncoder = Encoder::Stream;
|
Encoder recordingEncoder = Encoder::Stream;
|
||||||
@ -155,6 +159,10 @@ class AutoConfigStreamPage : public QWizardPage {
|
|||||||
|
|
||||||
friend class AutoConfig;
|
friend class AutoConfig;
|
||||||
|
|
||||||
|
enum class Section : int {
|
||||||
|
StreamKey,
|
||||||
|
};
|
||||||
|
|
||||||
Ui_AutoConfigStreamPage *ui;
|
Ui_AutoConfigStreamPage *ui;
|
||||||
QString lastService;
|
QString lastService;
|
||||||
bool ready = false;
|
bool ready = false;
|
||||||
|
300
UI/window-basic-settings-stream.cpp
Normal file
300
UI/window-basic-settings-stream.cpp
Normal file
@ -0,0 +1,300 @@
|
|||||||
|
#include <QMessageBox>
|
||||||
|
|
||||||
|
#include "window-basic-settings.hpp"
|
||||||
|
#include "obs-app.hpp"
|
||||||
|
#include "window-basic-main.hpp"
|
||||||
|
#include "qt-wrappers.hpp"
|
||||||
|
|
||||||
|
enum class ListOpt : int {
|
||||||
|
ShowAll = 1,
|
||||||
|
Custom,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum class Section : int {
|
||||||
|
StreamKey,
|
||||||
|
};
|
||||||
|
|
||||||
|
inline bool OBSBasicSettings::IsCustomService() const
|
||||||
|
{
|
||||||
|
return ui->service->currentData().toInt() == (int)ListOpt::Custom;
|
||||||
|
}
|
||||||
|
|
||||||
|
void OBSBasicSettings::InitStreamPage()
|
||||||
|
{
|
||||||
|
int vertSpacing = ui->topStreamLayout->verticalSpacing();
|
||||||
|
|
||||||
|
QMargins m = ui->topStreamLayout->contentsMargins();
|
||||||
|
m.setBottom(vertSpacing / 2);
|
||||||
|
ui->topStreamLayout->setContentsMargins(m);
|
||||||
|
|
||||||
|
m = ui->streamkeyPageLayout->contentsMargins();
|
||||||
|
m.setTop(vertSpacing / 2);
|
||||||
|
ui->streamkeyPageLayout->setContentsMargins(m);
|
||||||
|
|
||||||
|
LoadServices(false);
|
||||||
|
|
||||||
|
connect(ui->service, SIGNAL(currentIndexChanged(int)),
|
||||||
|
this, SLOT(UpdateServerList()));
|
||||||
|
connect(ui->service, SIGNAL(currentIndexChanged(int)),
|
||||||
|
this, SLOT(UpdateKeyLink()));
|
||||||
|
}
|
||||||
|
|
||||||
|
void OBSBasicSettings::LoadStream1Settings()
|
||||||
|
{
|
||||||
|
obs_service_t *service_obj = main->GetService();
|
||||||
|
const char *type = obs_service_get_type(service_obj);
|
||||||
|
|
||||||
|
loading = true;
|
||||||
|
|
||||||
|
obs_data_t *settings = obs_service_get_settings(service_obj);
|
||||||
|
|
||||||
|
const char *service = obs_data_get_string(settings, "service");
|
||||||
|
const char *server = obs_data_get_string(settings, "server");
|
||||||
|
const char *key = obs_data_get_string(settings, "key");
|
||||||
|
|
||||||
|
if (strcmp(type, "rtmp_custom") == 0) {
|
||||||
|
ui->service->setCurrentIndex(0);
|
||||||
|
ui->customServer->setText(server);
|
||||||
|
} else {
|
||||||
|
int idx = ui->service->findText(service);
|
||||||
|
if (idx == -1) {
|
||||||
|
if (service && *service)
|
||||||
|
ui->service->insertItem(1, service);
|
||||||
|
idx = 1;
|
||||||
|
}
|
||||||
|
ui->service->setCurrentIndex(idx);
|
||||||
|
}
|
||||||
|
|
||||||
|
UpdateServerList();
|
||||||
|
|
||||||
|
if (strcmp(type, "rtmp_common") == 0) {
|
||||||
|
int idx = ui->server->findData(server);
|
||||||
|
if (idx == -1) {
|
||||||
|
if (server && *server)
|
||||||
|
ui->server->insertItem(0, server, server);
|
||||||
|
idx = 0;
|
||||||
|
}
|
||||||
|
ui->server->setCurrentIndex(idx);
|
||||||
|
}
|
||||||
|
|
||||||
|
ui->key->setText(key);
|
||||||
|
|
||||||
|
lastService.clear();
|
||||||
|
on_service_currentIndexChanged(0);
|
||||||
|
|
||||||
|
obs_data_release(settings);
|
||||||
|
|
||||||
|
UpdateKeyLink();
|
||||||
|
|
||||||
|
loading = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void OBSBasicSettings::SaveStream1Settings()
|
||||||
|
{
|
||||||
|
bool customServer = IsCustomService();
|
||||||
|
const char *service_id = customServer
|
||||||
|
? "rtmp_custom"
|
||||||
|
: "rtmp_common";
|
||||||
|
|
||||||
|
obs_service_t *oldService = main->GetService();
|
||||||
|
OBSData hotkeyData = obs_hotkeys_save_service(oldService);
|
||||||
|
obs_data_release(hotkeyData);
|
||||||
|
|
||||||
|
OBSData settings = obs_data_create();
|
||||||
|
obs_data_release(settings);
|
||||||
|
|
||||||
|
if (!customServer) {
|
||||||
|
obs_data_set_string(settings, "service",
|
||||||
|
QT_TO_UTF8(ui->service->currentText()));
|
||||||
|
obs_data_set_string(settings, "server",
|
||||||
|
QT_TO_UTF8(ui->server->currentData().toString()));
|
||||||
|
} else {
|
||||||
|
obs_data_set_string(settings, "server",
|
||||||
|
QT_TO_UTF8(ui->customServer->text()));
|
||||||
|
}
|
||||||
|
|
||||||
|
obs_data_set_string(settings, "key", QT_TO_UTF8(ui->key->text()));
|
||||||
|
|
||||||
|
OBSService newService = obs_service_create(service_id,
|
||||||
|
"default_service", settings, hotkeyData);
|
||||||
|
obs_service_release(newService);
|
||||||
|
|
||||||
|
if (!newService)
|
||||||
|
return;
|
||||||
|
|
||||||
|
main->SetService(newService);
|
||||||
|
main->SaveService();
|
||||||
|
}
|
||||||
|
|
||||||
|
void OBSBasicSettings::UpdateKeyLink()
|
||||||
|
{
|
||||||
|
bool custom = IsCustomService();
|
||||||
|
QString serviceName = ui->service->currentText();
|
||||||
|
|
||||||
|
if (custom)
|
||||||
|
serviceName = "";
|
||||||
|
|
||||||
|
QString text = QTStr("Basic.AutoConfig.StreamPage.StreamKey");
|
||||||
|
if (serviceName == "Twitch") {
|
||||||
|
text += " <a href=\"https://";
|
||||||
|
text += "www.twitch.tv/broadcast/dashboard/streamkey";
|
||||||
|
text += "\">";
|
||||||
|
text += QTStr("Basic.AutoConfig.StreamPage.StreamKey.LinkToSite");
|
||||||
|
text += "</a>";
|
||||||
|
} else if (serviceName == "YouTube / YouTube Gaming") {
|
||||||
|
text += " <a href=\"https://";
|
||||||
|
text += "www.youtube.com/live_dashboard";
|
||||||
|
text += "\">";
|
||||||
|
text += QTStr("Basic.AutoConfig.StreamPage.StreamKey.LinkToSite");
|
||||||
|
text += "</a>";
|
||||||
|
}
|
||||||
|
|
||||||
|
ui->streamKeyLabel->setText(text);
|
||||||
|
}
|
||||||
|
|
||||||
|
void OBSBasicSettings::LoadServices(bool showAll)
|
||||||
|
{
|
||||||
|
obs_properties_t *props = obs_get_service_properties("rtmp_common");
|
||||||
|
|
||||||
|
OBSData settings = obs_data_create();
|
||||||
|
obs_data_release(settings);
|
||||||
|
|
||||||
|
obs_data_set_bool(settings, "show_all", showAll);
|
||||||
|
|
||||||
|
obs_property_t *prop = obs_properties_get(props, "show_all");
|
||||||
|
obs_property_modified(prop, settings);
|
||||||
|
|
||||||
|
ui->service->blockSignals(true);
|
||||||
|
ui->service->clear();
|
||||||
|
|
||||||
|
QStringList names;
|
||||||
|
|
||||||
|
obs_property_t *services = obs_properties_get(props, "service");
|
||||||
|
size_t services_count = obs_property_list_item_count(services);
|
||||||
|
for (size_t i = 0; i < services_count; i++) {
|
||||||
|
const char *name = obs_property_list_item_string(services, i);
|
||||||
|
names.push_back(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (showAll)
|
||||||
|
names.sort();
|
||||||
|
|
||||||
|
for (QString &name : names)
|
||||||
|
ui->service->addItem(name);
|
||||||
|
|
||||||
|
if (!showAll) {
|
||||||
|
ui->service->addItem(
|
||||||
|
QTStr("Basic.AutoConfig.StreamPage.Service.ShowAll"),
|
||||||
|
QVariant((int)ListOpt::ShowAll));
|
||||||
|
}
|
||||||
|
|
||||||
|
ui->service->insertItem(0,
|
||||||
|
QTStr("Basic.AutoConfig.StreamPage.Service.Custom"),
|
||||||
|
QVariant((int)ListOpt::Custom));
|
||||||
|
|
||||||
|
if (!lastService.isEmpty()) {
|
||||||
|
int idx = ui->service->findText(lastService);
|
||||||
|
if (idx != -1)
|
||||||
|
ui->service->setCurrentIndex(idx);
|
||||||
|
}
|
||||||
|
|
||||||
|
obs_properties_destroy(props);
|
||||||
|
|
||||||
|
ui->service->blockSignals(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
void OBSBasicSettings::on_service_currentIndexChanged(int)
|
||||||
|
{
|
||||||
|
bool showMore =
|
||||||
|
ui->service->currentData().toInt() == (int)ListOpt::ShowAll;
|
||||||
|
if (showMore)
|
||||||
|
return;
|
||||||
|
|
||||||
|
std::string service = QT_TO_UTF8(ui->service->currentText());
|
||||||
|
bool custom = IsCustomService();
|
||||||
|
|
||||||
|
if (custom) {
|
||||||
|
ui->streamkeyPageLayout->insertRow(1, ui->serverLabel,
|
||||||
|
ui->serverStackedWidget);
|
||||||
|
|
||||||
|
ui->serverStackedWidget->setCurrentIndex(1);
|
||||||
|
ui->serverStackedWidget->setVisible(true);
|
||||||
|
ui->serverLabel->setVisible(true);
|
||||||
|
} else {
|
||||||
|
ui->serverStackedWidget->setCurrentIndex(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void OBSBasicSettings::UpdateServerList()
|
||||||
|
{
|
||||||
|
QString serviceName = ui->service->currentText();
|
||||||
|
bool showMore =
|
||||||
|
ui->service->currentData().toInt() == (int)ListOpt::ShowAll;
|
||||||
|
|
||||||
|
if (showMore) {
|
||||||
|
LoadServices(true);
|
||||||
|
ui->service->showPopup();
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
lastService = serviceName;
|
||||||
|
}
|
||||||
|
|
||||||
|
obs_properties_t *props = obs_get_service_properties("rtmp_common");
|
||||||
|
obs_property_t *services = obs_properties_get(props, "service");
|
||||||
|
|
||||||
|
OBSData settings = obs_data_create();
|
||||||
|
obs_data_release(settings);
|
||||||
|
|
||||||
|
obs_data_set_string(settings, "service", QT_TO_UTF8(serviceName));
|
||||||
|
obs_property_modified(services, settings);
|
||||||
|
|
||||||
|
obs_property_t *servers = obs_properties_get(props, "server");
|
||||||
|
|
||||||
|
ui->server->clear();
|
||||||
|
|
||||||
|
size_t servers_count = obs_property_list_item_count(servers);
|
||||||
|
for (size_t i = 0; i < servers_count; i++) {
|
||||||
|
const char *name = obs_property_list_item_name(servers, i);
|
||||||
|
const char *server = obs_property_list_item_string(servers, i);
|
||||||
|
ui->server->addItem(name, server);
|
||||||
|
}
|
||||||
|
|
||||||
|
obs_properties_destroy(props);
|
||||||
|
}
|
||||||
|
|
||||||
|
void OBSBasicSettings::on_show_clicked()
|
||||||
|
{
|
||||||
|
if (ui->key->echoMode() == QLineEdit::Password) {
|
||||||
|
ui->key->setEchoMode(QLineEdit::Normal);
|
||||||
|
ui->show->setText(QTStr("Hide"));
|
||||||
|
} else {
|
||||||
|
ui->key->setEchoMode(QLineEdit::Password);
|
||||||
|
ui->show->setText(QTStr("Show"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
OBSService OBSBasicSettings::SpawnTempService()
|
||||||
|
{
|
||||||
|
bool custom = IsCustomService();
|
||||||
|
const char *service_id = custom ? "rtmp_custom" : "rtmp_common";
|
||||||
|
|
||||||
|
OBSData settings = obs_data_create();
|
||||||
|
obs_data_release(settings);
|
||||||
|
|
||||||
|
if (!custom) {
|
||||||
|
obs_data_set_string(settings, "service",
|
||||||
|
QT_TO_UTF8(ui->service->currentText()));
|
||||||
|
obs_data_set_string(settings, "server",
|
||||||
|
QT_TO_UTF8(ui->server->currentData().toString()));
|
||||||
|
} else {
|
||||||
|
obs_data_set_string(settings, "server",
|
||||||
|
QT_TO_UTF8(ui->customServer->text()));
|
||||||
|
}
|
||||||
|
obs_data_set_string(settings, "key", QT_TO_UTF8(ui->key->text()));
|
||||||
|
|
||||||
|
OBSService newService = obs_service_create(service_id,
|
||||||
|
"temp_service", settings, nullptr);
|
||||||
|
obs_service_release(newService);
|
||||||
|
|
||||||
|
return newService;
|
||||||
|
}
|
@ -322,8 +322,11 @@ OBSBasicSettings::OBSBasicSettings(QWidget *parent)
|
|||||||
HookWidget(ui->multiviewDrawNames, CHECK_CHANGED, GENERAL_CHANGED);
|
HookWidget(ui->multiviewDrawNames, CHECK_CHANGED, GENERAL_CHANGED);
|
||||||
HookWidget(ui->multiviewDrawAreas, CHECK_CHANGED, GENERAL_CHANGED);
|
HookWidget(ui->multiviewDrawAreas, CHECK_CHANGED, GENERAL_CHANGED);
|
||||||
HookWidget(ui->multiviewLayout, COMBO_CHANGED, GENERAL_CHANGED);
|
HookWidget(ui->multiviewLayout, COMBO_CHANGED, GENERAL_CHANGED);
|
||||||
|
HookWidget(ui->service, COMBO_CHANGED, STREAM1_CHANGED);
|
||||||
|
HookWidget(ui->server, COMBO_CHANGED, STREAM1_CHANGED);
|
||||||
|
HookWidget(ui->customServer, EDIT_CHANGED, STREAM1_CHANGED);
|
||||||
|
HookWidget(ui->key, EDIT_CHANGED, STREAM1_CHANGED);
|
||||||
HookWidget(ui->outputMode, COMBO_CHANGED, OUTPUTS_CHANGED);
|
HookWidget(ui->outputMode, COMBO_CHANGED, OUTPUTS_CHANGED);
|
||||||
HookWidget(ui->streamType, COMBO_CHANGED, STREAM1_CHANGED);
|
|
||||||
HookWidget(ui->simpleOutputPath, EDIT_CHANGED, OUTPUTS_CHANGED);
|
HookWidget(ui->simpleOutputPath, EDIT_CHANGED, OUTPUTS_CHANGED);
|
||||||
HookWidget(ui->simpleNoSpace, CHECK_CHANGED, OUTPUTS_CHANGED);
|
HookWidget(ui->simpleNoSpace, CHECK_CHANGED, OUTPUTS_CHANGED);
|
||||||
HookWidget(ui->simpleOutRecFormat, COMBO_CHANGED, OUTPUTS_CHANGED);
|
HookWidget(ui->simpleOutRecFormat, COMBO_CHANGED, OUTPUTS_CHANGED);
|
||||||
@ -560,7 +563,6 @@ OBSBasicSettings::OBSBasicSettings(QWidget *parent)
|
|||||||
|
|
||||||
installEventFilter(CreateShortcutFilter());
|
installEventFilter(CreateShortcutFilter());
|
||||||
|
|
||||||
LoadServiceTypes();
|
|
||||||
LoadEncoderTypes();
|
LoadEncoderTypes();
|
||||||
LoadColorRanges();
|
LoadColorRanges();
|
||||||
LoadFormats();
|
LoadFormats();
|
||||||
@ -691,6 +693,7 @@ OBSBasicSettings::OBSBasicSettings(QWidget *parent)
|
|||||||
|
|
||||||
obs_properties_destroy(ppts);
|
obs_properties_destroy(ppts);
|
||||||
|
|
||||||
|
InitStreamPage();
|
||||||
LoadSettings(false);
|
LoadSettings(false);
|
||||||
|
|
||||||
// Add warning checks to advanced output recording section controls
|
// Add warning checks to advanced output recording section controls
|
||||||
@ -770,23 +773,6 @@ void OBSBasicSettings::SaveSpinBox(QSpinBox *widget, const char *section,
|
|||||||
config_set_int(main->Config(), section, value, widget->value());
|
config_set_int(main->Config(), section, value, widget->value());
|
||||||
}
|
}
|
||||||
|
|
||||||
void OBSBasicSettings::LoadServiceTypes()
|
|
||||||
{
|
|
||||||
const char *type;
|
|
||||||
size_t idx = 0;
|
|
||||||
|
|
||||||
while (obs_enum_service_types(idx++, &type)) {
|
|
||||||
const char *name = obs_service_get_display_name(type);
|
|
||||||
QString qName = QT_UTF8(name);
|
|
||||||
QString qType = QT_UTF8(type);
|
|
||||||
|
|
||||||
ui->streamType->addItem(qName, qType);
|
|
||||||
}
|
|
||||||
|
|
||||||
type = obs_service_get_type(main->GetService());
|
|
||||||
SetComboByValue(ui->streamType, type);
|
|
||||||
}
|
|
||||||
|
|
||||||
#define TEXT_USE_STREAM_ENC \
|
#define TEXT_USE_STREAM_ENC \
|
||||||
QTStr("Basic.Settings.Output.Adv.Recording.UseStreamEncoder")
|
QTStr("Basic.Settings.Output.Adv.Recording.UseStreamEncoder")
|
||||||
|
|
||||||
@ -1145,37 +1131,6 @@ void OBSBasicSettings::LoadGeneralSettings()
|
|||||||
loading = false;
|
loading = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void OBSBasicSettings::LoadStream1Settings()
|
|
||||||
{
|
|
||||||
QLayout *layout = ui->streamContainer->layout();
|
|
||||||
obs_service_t *service = main->GetService();
|
|
||||||
const char *type = obs_service_get_type(service);
|
|
||||||
|
|
||||||
loading = true;
|
|
||||||
|
|
||||||
obs_data_t *settings = obs_service_get_settings(service);
|
|
||||||
|
|
||||||
delete streamProperties;
|
|
||||||
streamProperties = new OBSPropertiesView(settings, type,
|
|
||||||
(PropertiesReloadCallback)obs_get_service_properties,
|
|
||||||
170);
|
|
||||||
|
|
||||||
streamProperties->setProperty("changed", QVariant(false));
|
|
||||||
layout->addWidget(streamProperties);
|
|
||||||
|
|
||||||
QObject::connect(streamProperties, SIGNAL(Changed()),
|
|
||||||
this, STREAM1_CHANGED);
|
|
||||||
|
|
||||||
obs_data_release(settings);
|
|
||||||
|
|
||||||
loading = false;
|
|
||||||
|
|
||||||
if (main->StreamingActive()) {
|
|
||||||
ui->streamType->setEnabled(false);
|
|
||||||
ui->streamContainer->setEnabled(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void OBSBasicSettings::LoadRendererList()
|
void OBSBasicSettings::LoadRendererList()
|
||||||
{
|
{
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
@ -2809,26 +2764,6 @@ void OBSBasicSettings::SaveGeneralSettings()
|
|||||||
OBSProjector::UpdateMultiviewProjectors();
|
OBSProjector::UpdateMultiviewProjectors();
|
||||||
}
|
}
|
||||||
|
|
||||||
void OBSBasicSettings::SaveStream1Settings()
|
|
||||||
{
|
|
||||||
QString streamType = GetComboData(ui->streamType);
|
|
||||||
|
|
||||||
obs_service_t *oldService = main->GetService();
|
|
||||||
obs_data_t *hotkeyData = obs_hotkeys_save_service(oldService);
|
|
||||||
|
|
||||||
obs_service_t *newService = obs_service_create(QT_TO_UTF8(streamType),
|
|
||||||
"default_service", streamProperties->GetSettings(),
|
|
||||||
hotkeyData);
|
|
||||||
|
|
||||||
obs_data_release(hotkeyData);
|
|
||||||
if (!newService)
|
|
||||||
return;
|
|
||||||
|
|
||||||
main->SetService(newService);
|
|
||||||
main->SaveService();
|
|
||||||
obs_service_release(newService);
|
|
||||||
}
|
|
||||||
|
|
||||||
void OBSBasicSettings::SaveVideoSettings()
|
void OBSBasicSettings::SaveVideoSettings()
|
||||||
{
|
{
|
||||||
QString baseResolution = ui->baseResolution->currentText();
|
QString baseResolution = ui->baseResolution->currentText();
|
||||||
@ -3445,30 +3380,6 @@ void OBSBasicSettings::on_buttonBox_clicked(QAbstractButton *button)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void OBSBasicSettings::on_streamType_currentIndexChanged(int idx)
|
|
||||||
{
|
|
||||||
if (loading)
|
|
||||||
return;
|
|
||||||
|
|
||||||
QLayout *layout = ui->streamContainer->layout();
|
|
||||||
QString streamType = ui->streamType->itemData(idx).toString();
|
|
||||||
obs_data_t *settings = obs_service_defaults(QT_TO_UTF8(streamType));
|
|
||||||
|
|
||||||
delete streamProperties;
|
|
||||||
streamProperties = new OBSPropertiesView(settings,
|
|
||||||
QT_TO_UTF8(streamType),
|
|
||||||
(PropertiesReloadCallback)obs_get_service_properties,
|
|
||||||
170);
|
|
||||||
|
|
||||||
streamProperties->setProperty("changed", QVariant(true));
|
|
||||||
layout->addWidget(streamProperties);
|
|
||||||
|
|
||||||
QObject::connect(streamProperties, SIGNAL(Changed()),
|
|
||||||
this, STREAM1_CHANGED);
|
|
||||||
|
|
||||||
obs_data_release(settings);
|
|
||||||
}
|
|
||||||
|
|
||||||
void OBSBasicSettings::on_simpleOutputBrowse_clicked()
|
void OBSBasicSettings::on_simpleOutputBrowse_clicked()
|
||||||
{
|
{
|
||||||
QString dir = QFileDialog::getExistingDirectory(this,
|
QString dir = QFileDialog::getExistingDirectory(this,
|
||||||
@ -4318,11 +4229,7 @@ void OBSBasicSettings::SimpleRecordingEncoderChanged()
|
|||||||
OBSService service;
|
OBSService service;
|
||||||
|
|
||||||
if (stream1Changed) {
|
if (stream1Changed) {
|
||||||
QString streamType = GetComboData(ui->streamType);
|
service = SpawnTempService();
|
||||||
service = obs_service_create_private(
|
|
||||||
QT_TO_UTF8(streamType), nullptr,
|
|
||||||
streamProperties->GetSettings());
|
|
||||||
obs_service_release(service);
|
|
||||||
} else {
|
} else {
|
||||||
service = main->GetService();
|
service = main->GetService();
|
||||||
}
|
}
|
||||||
|
@ -20,12 +20,13 @@
|
|||||||
|
|
||||||
#include <util/util.hpp>
|
#include <util/util.hpp>
|
||||||
#include <QDialog>
|
#include <QDialog>
|
||||||
|
#include <QPointer>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include <libff/ff-util.h>
|
#include <libff/ff-util.h>
|
||||||
|
|
||||||
#include <obs.h>
|
#include <obs.hpp>
|
||||||
|
|
||||||
class OBSBasic;
|
class OBSBasic;
|
||||||
class QAbstractButton;
|
class QAbstractButton;
|
||||||
@ -185,7 +186,6 @@ private:
|
|||||||
|
|
||||||
bool QueryChanges();
|
bool QueryChanges();
|
||||||
|
|
||||||
void LoadServiceTypes();
|
|
||||||
void LoadEncoderTypes();
|
void LoadEncoderTypes();
|
||||||
void LoadColorRanges();
|
void LoadColorRanges();
|
||||||
void LoadFormats();
|
void LoadFormats();
|
||||||
@ -207,6 +207,17 @@ private:
|
|||||||
void LoadLanguageList();
|
void LoadLanguageList();
|
||||||
void LoadThemeList();
|
void LoadThemeList();
|
||||||
|
|
||||||
|
/* stream */
|
||||||
|
void InitStreamPage();
|
||||||
|
inline bool IsCustomService() const;
|
||||||
|
void LoadServices(bool showAll);
|
||||||
|
QString lastService;
|
||||||
|
private slots:
|
||||||
|
void UpdateServerList();
|
||||||
|
void UpdateKeyLink();
|
||||||
|
void on_show_clicked();
|
||||||
|
private:
|
||||||
|
|
||||||
/* output */
|
/* output */
|
||||||
void LoadSimpleOutputSettings();
|
void LoadSimpleOutputSettings();
|
||||||
void LoadAdvOutputStreamingSettings();
|
void LoadAdvOutputStreamingSettings();
|
||||||
@ -255,7 +266,7 @@ private slots:
|
|||||||
void on_listWidget_itemSelectionChanged();
|
void on_listWidget_itemSelectionChanged();
|
||||||
void on_buttonBox_clicked(QAbstractButton *button);
|
void on_buttonBox_clicked(QAbstractButton *button);
|
||||||
|
|
||||||
void on_streamType_currentIndexChanged(int idx);
|
void on_service_currentIndexChanged(int idx);
|
||||||
void on_simpleOutputBrowse_clicked();
|
void on_simpleOutputBrowse_clicked();
|
||||||
void on_advOutRecPathBrowse_clicked();
|
void on_advOutRecPathBrowse_clicked();
|
||||||
void on_advOutFFPathBrowse_clicked();
|
void on_advOutFFPathBrowse_clicked();
|
||||||
@ -306,6 +317,8 @@ private slots:
|
|||||||
|
|
||||||
void SimpleStreamingEncoderChanged();
|
void SimpleStreamingEncoderChanged();
|
||||||
|
|
||||||
|
OBSService SpawnTempService();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void closeEvent(QCloseEvent *event);
|
virtual void closeEvent(QCloseEvent *event);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user