2021-03-22 01:46:46 -04:00
|
|
|
#include "window-basic-main.hpp"
|
2018-08-23 20:43:44 -05:00
|
|
|
#include "context-bar-controls.hpp"
|
|
|
|
#include "qt-wrappers.hpp"
|
|
|
|
#include "obs-app.hpp"
|
|
|
|
|
|
|
|
#include <QStandardItemModel>
|
|
|
|
#include <QColorDialog>
|
|
|
|
#include <QFontDialog>
|
|
|
|
|
|
|
|
#include "ui_browser-source-toolbar.h"
|
|
|
|
#include "ui_device-select-toolbar.h"
|
|
|
|
#include "ui_game-capture-toolbar.h"
|
|
|
|
#include "ui_image-source-toolbar.h"
|
|
|
|
#include "ui_color-source-toolbar.h"
|
|
|
|
#include "ui_text-source-toolbar.h"
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
|
|
|
#define get_os_module(win, mac, linux) obs_get_module(win)
|
|
|
|
#define get_os_text(mod, win, mac, linux) obs_module_get_locale_text(mod, win)
|
|
|
|
#elif __APPLE__
|
|
|
|
#define get_os_module(win, mac, linux) obs_get_module(mac)
|
|
|
|
#define get_os_text(mod, win, mac, linux) obs_module_get_locale_text(mod, mac)
|
|
|
|
#else
|
|
|
|
#define get_os_module(win, mac, linux) obs_get_module(linux)
|
|
|
|
#define get_os_text(mod, win, mac, linux) obs_module_get_locale_text(mod, linux)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* ========================================================================= */
|
|
|
|
|
|
|
|
SourceToolbar::SourceToolbar(QWidget *parent, OBSSource source)
|
|
|
|
: QWidget(parent),
|
|
|
|
weakSource(OBSGetWeakRef(source)),
|
|
|
|
props(obs_source_properties(source), obs_properties_destroy)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2021-03-22 01:46:46 -04:00
|
|
|
void SourceToolbar::SaveOldProperties(obs_source_t *source)
|
|
|
|
{
|
|
|
|
oldData = obs_data_create();
|
2021-06-10 13:51:53 -07:00
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease oldSettings = obs_source_get_settings(source);
|
2021-03-22 01:46:46 -04:00
|
|
|
obs_data_apply(oldData, oldSettings);
|
|
|
|
obs_data_set_string(oldData, "undo_sname", obs_source_get_name(source));
|
|
|
|
}
|
|
|
|
|
2021-11-05 21:42:41 +01:00
|
|
|
void SourceToolbar::SetUndoProperties(obs_source_t *source, bool repeatable)
|
2021-03-22 01:46:46 -04:00
|
|
|
{
|
2021-06-10 13:51:53 -07:00
|
|
|
if (!oldData) {
|
|
|
|
blog(LOG_ERROR, "%s: somehow oldData was null.", __FUNCTION__);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2021-03-22 01:46:46 -04:00
|
|
|
OBSBasic *main = reinterpret_cast<OBSBasic *>(App()->GetMainWindow());
|
|
|
|
|
2021-11-20 02:58:24 +01:00
|
|
|
OBSSource currentSceneSource = main->GetCurrentSceneSource();
|
|
|
|
if (!currentSceneSource)
|
|
|
|
return;
|
|
|
|
std::string scene_name = obs_source_get_name(currentSceneSource);
|
2021-03-22 01:46:46 -04:00
|
|
|
auto undo_redo = [scene_name,
|
|
|
|
main = std::move(main)](const std::string &data) {
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings =
|
|
|
|
obs_data_create_from_json(data.c_str());
|
|
|
|
OBSSourceAutoRelease source = obs_get_source_by_name(
|
2021-03-22 01:46:46 -04:00
|
|
|
obs_data_get_string(settings, "undo_sname"));
|
2021-04-30 18:31:13 -07:00
|
|
|
obs_source_reset_settings(source, settings);
|
2021-03-22 01:46:46 -04:00
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSSourceAutoRelease scene_source =
|
2021-03-22 01:46:46 -04:00
|
|
|
obs_get_source_by_name(scene_name.c_str());
|
2021-11-26 22:25:39 +13:00
|
|
|
main->SetCurrentScene(scene_source.Get(), true);
|
2021-03-22 01:46:46 -04:00
|
|
|
|
|
|
|
main->UpdateContextBar();
|
|
|
|
};
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease new_settings = obs_data_create();
|
|
|
|
OBSDataAutoRelease curr_settings = obs_source_get_settings(source);
|
2021-03-22 01:46:46 -04:00
|
|
|
obs_data_apply(new_settings, curr_settings);
|
|
|
|
obs_data_set_string(new_settings, "undo_sname",
|
|
|
|
obs_source_get_name(source));
|
|
|
|
|
|
|
|
std::string undo_data(obs_data_get_json(oldData));
|
|
|
|
std::string redo_data(obs_data_get_json(new_settings));
|
|
|
|
|
|
|
|
if (undo_data.compare(redo_data) != 0)
|
|
|
|
main->undo_s.add_action(
|
|
|
|
QTStr("Undo.Properties")
|
|
|
|
.arg(obs_source_get_name(source)),
|
2021-11-05 21:42:41 +01:00
|
|
|
undo_redo, undo_redo, undo_data, redo_data, repeatable);
|
2021-03-22 01:46:46 -04:00
|
|
|
|
2021-06-10 13:51:53 -07:00
|
|
|
oldData = nullptr;
|
2021-03-22 01:46:46 -04:00
|
|
|
}
|
|
|
|
|
2018-08-23 20:43:44 -05:00
|
|
|
/* ========================================================================= */
|
|
|
|
|
|
|
|
BrowserToolbar::BrowserToolbar(QWidget *parent, OBSSource source)
|
|
|
|
: SourceToolbar(parent, source), ui(new Ui_BrowserSourceToolbar)
|
|
|
|
{
|
|
|
|
ui->setupUi(this);
|
|
|
|
}
|
|
|
|
|
2022-02-17 08:33:56 -06:00
|
|
|
BrowserToolbar::~BrowserToolbar() {}
|
2018-08-23 20:43:44 -05:00
|
|
|
|
|
|
|
void BrowserToolbar::on_refresh_clicked()
|
|
|
|
{
|
|
|
|
OBSSource source = GetSource();
|
|
|
|
if (!source) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
obs_property_t *p = obs_properties_get(props.get(), "refreshnocache");
|
|
|
|
obs_property_button_clicked(p, source.Get());
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ========================================================================= */
|
|
|
|
|
|
|
|
ComboSelectToolbar::ComboSelectToolbar(QWidget *parent, OBSSource source)
|
|
|
|
: SourceToolbar(parent, source), ui(new Ui_DeviceSelectToolbar)
|
|
|
|
{
|
|
|
|
ui->setupUi(this);
|
|
|
|
}
|
|
|
|
|
2022-02-17 08:33:56 -06:00
|
|
|
ComboSelectToolbar::~ComboSelectToolbar() {}
|
2018-08-23 20:43:44 -05:00
|
|
|
|
|
|
|
static int FillPropertyCombo(QComboBox *c, obs_property_t *p,
|
|
|
|
const std::string &cur_id, bool is_int = false)
|
|
|
|
{
|
|
|
|
size_t count = obs_property_list_item_count(p);
|
|
|
|
int cur_idx = -1;
|
|
|
|
|
|
|
|
for (size_t i = 0; i < count; i++) {
|
|
|
|
const char *name = obs_property_list_item_name(p, i);
|
|
|
|
std::string id;
|
|
|
|
|
|
|
|
if (is_int) {
|
|
|
|
id = std::to_string(obs_property_list_item_int(p, i));
|
|
|
|
} else {
|
|
|
|
const char *val = obs_property_list_item_string(p, i);
|
|
|
|
id = val ? val : "";
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cur_id == id)
|
|
|
|
cur_idx = (int)i;
|
|
|
|
|
|
|
|
c->addItem(name, id.c_str());
|
|
|
|
}
|
|
|
|
|
|
|
|
return cur_idx;
|
|
|
|
}
|
|
|
|
|
2020-08-25 08:16:56 -07:00
|
|
|
void UpdateSourceComboToolbarProperties(QComboBox *combo, OBSSource source,
|
|
|
|
obs_properties_t *props,
|
|
|
|
const char *prop_name, bool is_int)
|
2018-08-23 20:43:44 -05:00
|
|
|
{
|
|
|
|
std::string cur_id;
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_source_get_settings(source);
|
2018-08-23 20:43:44 -05:00
|
|
|
if (is_int) {
|
|
|
|
cur_id = std::to_string(obs_data_get_int(settings, prop_name));
|
|
|
|
} else {
|
|
|
|
cur_id = obs_data_get_string(settings, prop_name);
|
|
|
|
}
|
|
|
|
|
2020-08-25 08:16:56 -07:00
|
|
|
combo->blockSignals(true);
|
2018-08-23 20:43:44 -05:00
|
|
|
|
2020-08-25 08:16:56 -07:00
|
|
|
obs_property_t *p = obs_properties_get(props, prop_name);
|
|
|
|
int cur_idx = FillPropertyCombo(combo, p, cur_id, is_int);
|
2018-08-23 20:43:44 -05:00
|
|
|
|
|
|
|
if (cur_idx == -1 || obs_property_list_item_disabled(p, cur_idx)) {
|
|
|
|
if (cur_idx == -1) {
|
2020-08-25 08:16:56 -07:00
|
|
|
combo->insertItem(
|
2018-08-23 20:43:44 -05:00
|
|
|
0,
|
|
|
|
QTStr("Basic.Settings.Audio.UnknownAudioDevice"));
|
|
|
|
cur_idx = 0;
|
|
|
|
}
|
|
|
|
|
2020-11-08 03:54:11 -08:00
|
|
|
SetComboItemEnabled(combo, cur_idx, false);
|
2020-08-25 08:16:56 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
combo->setCurrentIndex(cur_idx);
|
|
|
|
combo->blockSignals(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ComboSelectToolbar::Init()
|
|
|
|
{
|
|
|
|
OBSSource source = GetSource();
|
|
|
|
if (!source) {
|
|
|
|
return;
|
2018-08-23 20:43:44 -05:00
|
|
|
}
|
|
|
|
|
2020-08-25 08:16:56 -07:00
|
|
|
UpdateSourceComboToolbarProperties(ui->device, source, props.get(),
|
|
|
|
prop_name, is_int);
|
2018-08-23 20:43:44 -05:00
|
|
|
}
|
|
|
|
|
2020-08-25 08:16:56 -07:00
|
|
|
void UpdateSourceComboToolbarValue(QComboBox *combo, OBSSource source, int idx,
|
|
|
|
const char *prop_name, bool is_int)
|
2018-08-23 20:43:44 -05:00
|
|
|
{
|
2020-08-25 08:16:56 -07:00
|
|
|
QString id = combo->itemData(idx).toString();
|
2018-08-23 20:43:44 -05:00
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_data_create();
|
2018-08-23 20:43:44 -05:00
|
|
|
if (is_int) {
|
|
|
|
obs_data_set_int(settings, prop_name, id.toInt());
|
|
|
|
} else {
|
|
|
|
obs_data_set_string(settings, prop_name, QT_TO_UTF8(id));
|
|
|
|
}
|
|
|
|
obs_source_update(source, settings);
|
|
|
|
}
|
|
|
|
|
2020-08-25 08:16:56 -07:00
|
|
|
void ComboSelectToolbar::on_device_currentIndexChanged(int idx)
|
|
|
|
{
|
|
|
|
OBSSource source = GetSource();
|
|
|
|
if (idx == -1 || !source) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2021-03-22 01:46:46 -04:00
|
|
|
SaveOldProperties(source);
|
2020-08-25 08:16:56 -07:00
|
|
|
UpdateSourceComboToolbarValue(ui->device, source, idx, prop_name,
|
|
|
|
is_int);
|
2021-03-22 01:46:46 -04:00
|
|
|
SetUndoProperties(source);
|
2020-08-25 08:16:56 -07:00
|
|
|
}
|
|
|
|
|
2018-08-23 20:43:44 -05:00
|
|
|
AudioCaptureToolbar::AudioCaptureToolbar(QWidget *parent, OBSSource source)
|
|
|
|
: ComboSelectToolbar(parent, source)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void AudioCaptureToolbar::Init()
|
|
|
|
{
|
|
|
|
delete ui->activateButton;
|
|
|
|
ui->activateButton = nullptr;
|
|
|
|
|
|
|
|
obs_module_t *mod =
|
|
|
|
get_os_module("win-wasapi", "mac-capture", "linux-pulseaudio");
|
2022-06-20 20:56:53 +09:00
|
|
|
if (!mod)
|
2020-12-30 03:14:34 +02:00
|
|
|
return;
|
|
|
|
|
2018-08-23 20:43:44 -05:00
|
|
|
const char *device_str =
|
|
|
|
get_os_text(mod, "Device", "CoreAudio.Device", "Device");
|
|
|
|
ui->deviceLabel->setText(device_str);
|
|
|
|
|
|
|
|
prop_name = "device_id";
|
|
|
|
|
|
|
|
ComboSelectToolbar::Init();
|
|
|
|
}
|
|
|
|
|
|
|
|
WindowCaptureToolbar::WindowCaptureToolbar(QWidget *parent, OBSSource source)
|
|
|
|
: ComboSelectToolbar(parent, source)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void WindowCaptureToolbar::Init()
|
|
|
|
{
|
|
|
|
delete ui->activateButton;
|
|
|
|
ui->activateButton = nullptr;
|
|
|
|
|
|
|
|
obs_module_t *mod =
|
|
|
|
get_os_module("win-capture", "mac-capture", "linux-capture");
|
2022-06-20 20:56:53 +09:00
|
|
|
if (!mod)
|
|
|
|
return;
|
|
|
|
|
2018-08-23 20:43:44 -05:00
|
|
|
const char *device_str = get_os_text(mod, "WindowCapture.Window",
|
|
|
|
"WindowUtils.Window", "Window");
|
|
|
|
ui->deviceLabel->setText(device_str);
|
|
|
|
|
|
|
|
#if !defined(_WIN32) && !defined(__APPLE__) //linux
|
|
|
|
prop_name = "capture_window";
|
|
|
|
#else
|
|
|
|
prop_name = "window";
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef __APPLE__
|
|
|
|
is_int = true;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
ComboSelectToolbar::Init();
|
|
|
|
}
|
|
|
|
|
|
|
|
DisplayCaptureToolbar::DisplayCaptureToolbar(QWidget *parent, OBSSource source)
|
|
|
|
: ComboSelectToolbar(parent, source)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void DisplayCaptureToolbar::Init()
|
|
|
|
{
|
|
|
|
delete ui->activateButton;
|
|
|
|
ui->activateButton = nullptr;
|
|
|
|
|
|
|
|
obs_module_t *mod =
|
|
|
|
get_os_module("win-capture", "mac-capture", "linux-capture");
|
2022-06-20 20:56:53 +09:00
|
|
|
if (!mod)
|
|
|
|
return;
|
|
|
|
|
2018-08-23 20:43:44 -05:00
|
|
|
const char *device_str =
|
|
|
|
get_os_text(mod, "Monitor", "DisplayCapture.Display", "Screen");
|
|
|
|
ui->deviceLabel->setText(device_str);
|
|
|
|
is_int = true;
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
|
|
|
prop_name = "monitor";
|
|
|
|
#elif __APPLE__
|
|
|
|
prop_name = "display";
|
|
|
|
#else
|
|
|
|
prop_name = "screen";
|
|
|
|
#endif
|
|
|
|
|
|
|
|
ComboSelectToolbar::Init();
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ========================================================================= */
|
|
|
|
|
UI: Replace/simplify device toolbar
The old version of the device toolbar was a complex situation. Because
of the fact that device properties can take significant time to query,
this put an unpleasant burden on the UI thread; so to fix this problem,
the device toolbar was made to be threaded. However, threading is a
complex and dangerous thing, and there is a fear that this could cause
complications down the line whenever users are simply selecting devices.
So for the time being, as a safety precaution, simplify the device
toolbar down to just the "activate" button, and make it so that if users
really need to query and change the devices, that they need to
explicitly open the properties. That way the devices aren't being
queried constantly every time a device source is selected.
Alternatively in the future, device enumeration could be cached, but
seeing as that's a significant amount of work and needs to take in to
account whether a user adds/removes a device while the process is
active, that's not going to happen any time soon.
2020-09-07 16:14:30 -07:00
|
|
|
DeviceCaptureToolbar::DeviceCaptureToolbar(QWidget *parent, OBSSource source)
|
|
|
|
: QWidget(parent),
|
|
|
|
weakSource(OBSGetWeakRef(source)),
|
|
|
|
ui(new Ui_DeviceSelectToolbar)
|
|
|
|
{
|
|
|
|
ui->setupUi(this);
|
|
|
|
|
|
|
|
delete ui->deviceLabel;
|
|
|
|
delete ui->device;
|
|
|
|
ui->deviceLabel = nullptr;
|
|
|
|
ui->device = nullptr;
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_source_get_settings(source);
|
UI: Replace/simplify device toolbar
The old version of the device toolbar was a complex situation. Because
of the fact that device properties can take significant time to query,
this put an unpleasant burden on the UI thread; so to fix this problem,
the device toolbar was made to be threaded. However, threading is a
complex and dangerous thing, and there is a fear that this could cause
complications down the line whenever users are simply selecting devices.
So for the time being, as a safety precaution, simplify the device
toolbar down to just the "activate" button, and make it so that if users
really need to query and change the devices, that they need to
explicitly open the properties. That way the devices aren't being
queried constantly every time a device source is selected.
Alternatively in the future, device enumeration could be cached, but
seeing as that's a significant amount of work and needs to take in to
account whether a user adds/removes a device while the process is
active, that's not going to happen any time soon.
2020-09-07 16:14:30 -07:00
|
|
|
active = obs_data_get_bool(settings, "active");
|
|
|
|
|
|
|
|
obs_module_t *mod = obs_get_module("win-dshow");
|
2022-01-23 16:45:54 +11:00
|
|
|
if (!mod)
|
|
|
|
return;
|
|
|
|
|
UI: Replace/simplify device toolbar
The old version of the device toolbar was a complex situation. Because
of the fact that device properties can take significant time to query,
this put an unpleasant burden on the UI thread; so to fix this problem,
the device toolbar was made to be threaded. However, threading is a
complex and dangerous thing, and there is a fear that this could cause
complications down the line whenever users are simply selecting devices.
So for the time being, as a safety precaution, simplify the device
toolbar down to just the "activate" button, and make it so that if users
really need to query and change the devices, that they need to
explicitly open the properties. That way the devices aren't being
queried constantly every time a device source is selected.
Alternatively in the future, device enumeration could be cached, but
seeing as that's a significant amount of work and needs to take in to
account whether a user adds/removes a device while the process is
active, that's not going to happen any time soon.
2020-09-07 16:14:30 -07:00
|
|
|
activateText = obs_module_get_locale_text(mod, "Activate");
|
|
|
|
deactivateText = obs_module_get_locale_text(mod, "Deactivate");
|
|
|
|
|
|
|
|
ui->activateButton->setText(active ? deactivateText : activateText);
|
|
|
|
}
|
|
|
|
|
2022-02-17 08:33:56 -06:00
|
|
|
DeviceCaptureToolbar::~DeviceCaptureToolbar() {}
|
UI: Replace/simplify device toolbar
The old version of the device toolbar was a complex situation. Because
of the fact that device properties can take significant time to query,
this put an unpleasant burden on the UI thread; so to fix this problem,
the device toolbar was made to be threaded. However, threading is a
complex and dangerous thing, and there is a fear that this could cause
complications down the line whenever users are simply selecting devices.
So for the time being, as a safety precaution, simplify the device
toolbar down to just the "activate" button, and make it so that if users
really need to query and change the devices, that they need to
explicitly open the properties. That way the devices aren't being
queried constantly every time a device source is selected.
Alternatively in the future, device enumeration could be cached, but
seeing as that's a significant amount of work and needs to take in to
account whether a user adds/removes a device while the process is
active, that's not going to happen any time soon.
2020-09-07 16:14:30 -07:00
|
|
|
|
|
|
|
void DeviceCaptureToolbar::on_activateButton_clicked()
|
|
|
|
{
|
|
|
|
OBSSource source = OBSGetStrongRef(weakSource);
|
|
|
|
if (!source) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_source_get_settings(source);
|
UI: Replace/simplify device toolbar
The old version of the device toolbar was a complex situation. Because
of the fact that device properties can take significant time to query,
this put an unpleasant burden on the UI thread; so to fix this problem,
the device toolbar was made to be threaded. However, threading is a
complex and dangerous thing, and there is a fear that this could cause
complications down the line whenever users are simply selecting devices.
So for the time being, as a safety precaution, simplify the device
toolbar down to just the "activate" button, and make it so that if users
really need to query and change the devices, that they need to
explicitly open the properties. That way the devices aren't being
queried constantly every time a device source is selected.
Alternatively in the future, device enumeration could be cached, but
seeing as that's a significant amount of work and needs to take in to
account whether a user adds/removes a device while the process is
active, that's not going to happen any time soon.
2020-09-07 16:14:30 -07:00
|
|
|
bool now_active = obs_data_get_bool(settings, "active");
|
|
|
|
|
|
|
|
bool desyncedSetting = now_active != active;
|
|
|
|
|
|
|
|
active = !active;
|
|
|
|
|
|
|
|
const char *text = active ? deactivateText : activateText;
|
|
|
|
ui->activateButton->setText(text);
|
|
|
|
|
|
|
|
if (desyncedSetting) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
calldata_t cd = {};
|
|
|
|
calldata_set_bool(&cd, "active", active);
|
|
|
|
proc_handler_t *ph = obs_source_get_proc_handler(source);
|
|
|
|
proc_handler_call(ph, "activate", &cd);
|
|
|
|
calldata_free(&cd);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ========================================================================= */
|
|
|
|
|
2018-08-23 20:43:44 -05:00
|
|
|
GameCaptureToolbar::GameCaptureToolbar(QWidget *parent, OBSSource source)
|
|
|
|
: SourceToolbar(parent, source), ui(new Ui_GameCaptureToolbar)
|
|
|
|
{
|
|
|
|
obs_property_t *p;
|
|
|
|
int cur_idx;
|
|
|
|
|
|
|
|
ui->setupUi(this);
|
|
|
|
|
|
|
|
obs_module_t *mod = obs_get_module("win-capture");
|
2022-01-23 16:45:54 +11:00
|
|
|
if (!mod)
|
|
|
|
return;
|
|
|
|
|
2018-08-23 20:43:44 -05:00
|
|
|
ui->modeLabel->setText(obs_module_get_locale_text(mod, "Mode"));
|
|
|
|
ui->windowLabel->setText(
|
|
|
|
obs_module_get_locale_text(mod, "WindowCapture.Window"));
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_source_get_settings(source);
|
2018-08-23 20:43:44 -05:00
|
|
|
std::string cur_mode = obs_data_get_string(settings, "capture_mode");
|
|
|
|
std::string cur_window = obs_data_get_string(settings, "window");
|
|
|
|
|
|
|
|
ui->mode->blockSignals(true);
|
|
|
|
p = obs_properties_get(props.get(), "capture_mode");
|
|
|
|
cur_idx = FillPropertyCombo(ui->mode, p, cur_mode);
|
|
|
|
ui->mode->setCurrentIndex(cur_idx);
|
|
|
|
ui->mode->blockSignals(false);
|
|
|
|
|
|
|
|
ui->window->blockSignals(true);
|
|
|
|
p = obs_properties_get(props.get(), "window");
|
|
|
|
cur_idx = FillPropertyCombo(ui->window, p, cur_window);
|
|
|
|
ui->window->setCurrentIndex(cur_idx);
|
|
|
|
ui->window->blockSignals(false);
|
|
|
|
|
|
|
|
if (cur_idx != -1 && obs_property_list_item_disabled(p, cur_idx)) {
|
2020-11-08 03:54:11 -08:00
|
|
|
SetComboItemEnabled(ui->window, cur_idx, false);
|
2018-08-23 20:43:44 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
UpdateWindowVisibility();
|
|
|
|
}
|
|
|
|
|
2022-02-17 08:33:56 -06:00
|
|
|
GameCaptureToolbar::~GameCaptureToolbar() {}
|
2018-08-23 20:43:44 -05:00
|
|
|
|
|
|
|
void GameCaptureToolbar::UpdateWindowVisibility()
|
|
|
|
{
|
|
|
|
QString mode = ui->mode->currentData().toString();
|
|
|
|
bool is_window = (mode == "window");
|
|
|
|
ui->windowLabel->setVisible(is_window);
|
|
|
|
ui->window->setVisible(is_window);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GameCaptureToolbar::on_mode_currentIndexChanged(int idx)
|
|
|
|
{
|
|
|
|
OBSSource source = GetSource();
|
|
|
|
if (idx == -1 || !source) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
QString id = ui->mode->itemData(idx).toString();
|
|
|
|
|
2021-03-22 01:46:46 -04:00
|
|
|
SaveOldProperties(source);
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_data_create();
|
2018-08-23 20:43:44 -05:00
|
|
|
obs_data_set_string(settings, "capture_mode", QT_TO_UTF8(id));
|
|
|
|
obs_source_update(source, settings);
|
2021-03-22 01:46:46 -04:00
|
|
|
SetUndoProperties(source);
|
2018-08-23 20:43:44 -05:00
|
|
|
|
|
|
|
UpdateWindowVisibility();
|
|
|
|
}
|
|
|
|
|
|
|
|
void GameCaptureToolbar::on_window_currentIndexChanged(int idx)
|
|
|
|
{
|
|
|
|
OBSSource source = GetSource();
|
|
|
|
if (idx == -1 || !source) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
QString id = ui->window->itemData(idx).toString();
|
|
|
|
|
2021-03-22 01:46:46 -04:00
|
|
|
SaveOldProperties(source);
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_data_create();
|
2018-08-23 20:43:44 -05:00
|
|
|
obs_data_set_string(settings, "window", QT_TO_UTF8(id));
|
|
|
|
obs_source_update(source, settings);
|
2021-03-22 01:46:46 -04:00
|
|
|
SetUndoProperties(source);
|
2018-08-23 20:43:44 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/* ========================================================================= */
|
|
|
|
|
|
|
|
ImageSourceToolbar::ImageSourceToolbar(QWidget *parent, OBSSource source)
|
|
|
|
: SourceToolbar(parent, source), ui(new Ui_ImageSourceToolbar)
|
|
|
|
{
|
|
|
|
ui->setupUi(this);
|
|
|
|
|
|
|
|
obs_module_t *mod = obs_get_module("image-source");
|
|
|
|
ui->pathLabel->setText(obs_module_get_locale_text(mod, "File"));
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_source_get_settings(source);
|
2018-08-23 20:43:44 -05:00
|
|
|
std::string file = obs_data_get_string(settings, "file");
|
|
|
|
|
|
|
|
ui->path->setText(file.c_str());
|
|
|
|
}
|
|
|
|
|
2022-02-17 08:33:56 -06:00
|
|
|
ImageSourceToolbar::~ImageSourceToolbar() {}
|
2018-08-23 20:43:44 -05:00
|
|
|
|
|
|
|
void ImageSourceToolbar::on_browse_clicked()
|
|
|
|
{
|
|
|
|
OBSSource source = GetSource();
|
|
|
|
if (!source) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
obs_property_t *p = obs_properties_get(props.get(), "file");
|
|
|
|
const char *desc = obs_property_description(p);
|
|
|
|
const char *filter = obs_property_path_filter(p);
|
|
|
|
const char *default_path = obs_property_path_default_path(p);
|
|
|
|
|
|
|
|
QString path = OpenFile(this, desc, default_path, filter);
|
|
|
|
if (path.isEmpty()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ui->path->setText(path);
|
|
|
|
|
2021-03-22 01:46:46 -04:00
|
|
|
SaveOldProperties(source);
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_data_create();
|
2018-08-23 20:43:44 -05:00
|
|
|
obs_data_set_string(settings, "file", QT_TO_UTF8(path));
|
|
|
|
obs_source_update(source, settings);
|
2021-03-22 01:46:46 -04:00
|
|
|
SetUndoProperties(source);
|
2018-08-23 20:43:44 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/* ========================================================================= */
|
|
|
|
|
|
|
|
static inline QColor color_from_int(long long val)
|
|
|
|
{
|
|
|
|
return QColor(val & 0xff, (val >> 8) & 0xff, (val >> 16) & 0xff,
|
|
|
|
(val >> 24) & 0xff);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline long long color_to_int(QColor color)
|
|
|
|
{
|
|
|
|
auto shift = [&](unsigned val, int shift) {
|
|
|
|
return ((val & 0xff) << shift);
|
|
|
|
};
|
|
|
|
|
|
|
|
return shift(color.red(), 0) | shift(color.green(), 8) |
|
|
|
|
shift(color.blue(), 16) | shift(color.alpha(), 24);
|
|
|
|
}
|
|
|
|
|
|
|
|
ColorSourceToolbar::ColorSourceToolbar(QWidget *parent, OBSSource source)
|
|
|
|
: SourceToolbar(parent, source), ui(new Ui_ColorSourceToolbar)
|
|
|
|
{
|
|
|
|
ui->setupUi(this);
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_source_get_settings(source);
|
2018-08-23 20:43:44 -05:00
|
|
|
unsigned int val = (unsigned int)obs_data_get_int(settings, "color");
|
|
|
|
|
|
|
|
color = color_from_int(val);
|
|
|
|
UpdateColor();
|
|
|
|
}
|
|
|
|
|
2022-02-17 08:33:56 -06:00
|
|
|
ColorSourceToolbar::~ColorSourceToolbar() {}
|
2018-08-23 20:43:44 -05:00
|
|
|
|
|
|
|
void ColorSourceToolbar::UpdateColor()
|
|
|
|
{
|
|
|
|
QPalette palette = QPalette(color);
|
|
|
|
ui->color->setFrameStyle(QFrame::Sunken | QFrame::Panel);
|
|
|
|
ui->color->setText(color.name(QColor::HexRgb));
|
|
|
|
ui->color->setPalette(palette);
|
|
|
|
ui->color->setStyleSheet(
|
|
|
|
QString("background-color :%1; color: %2;")
|
|
|
|
.arg(palette.color(QPalette::Window)
|
|
|
|
.name(QColor::HexRgb))
|
|
|
|
.arg(palette.color(QPalette::WindowText)
|
|
|
|
.name(QColor::HexRgb)));
|
|
|
|
ui->color->setAutoFillBackground(true);
|
|
|
|
ui->color->setAlignment(Qt::AlignCenter);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ColorSourceToolbar::on_choose_clicked()
|
|
|
|
{
|
|
|
|
OBSSource source = GetSource();
|
|
|
|
if (!source) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
obs_property_t *p = obs_properties_get(props.get(), "color");
|
|
|
|
const char *desc = obs_property_description(p);
|
|
|
|
|
|
|
|
QColorDialog::ColorDialogOptions options;
|
|
|
|
|
2021-09-19 19:18:26 +02:00
|
|
|
options |= QColorDialog::ShowAlphaChannel;
|
2018-08-23 20:43:44 -05:00
|
|
|
#ifndef _WIN32
|
|
|
|
options |= QColorDialog::DontUseNativeDialog;
|
|
|
|
#endif
|
|
|
|
|
2020-09-03 05:14:28 -07:00
|
|
|
QColor newColor = QColorDialog::getColor(color, this, desc, options);
|
|
|
|
if (!newColor.isValid()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
color = newColor;
|
2018-08-23 20:43:44 -05:00
|
|
|
UpdateColor();
|
|
|
|
|
2021-03-22 01:46:46 -04:00
|
|
|
SaveOldProperties(source);
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_data_create();
|
2018-08-23 20:43:44 -05:00
|
|
|
obs_data_set_int(settings, "color", color_to_int(color));
|
|
|
|
obs_source_update(source, settings);
|
2021-03-22 01:46:46 -04:00
|
|
|
|
|
|
|
SetUndoProperties(source);
|
2018-08-23 20:43:44 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/* ========================================================================= */
|
|
|
|
|
|
|
|
extern void MakeQFont(obs_data_t *font_obj, QFont &font, bool limit = false);
|
|
|
|
|
|
|
|
TextSourceToolbar::TextSourceToolbar(QWidget *parent, OBSSource source)
|
|
|
|
: SourceToolbar(parent, source), ui(new Ui_TextSourceToolbar)
|
|
|
|
{
|
|
|
|
ui->setupUi(this);
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_source_get_settings(source);
|
2018-08-23 20:43:44 -05:00
|
|
|
|
|
|
|
const char *id = obs_source_get_unversioned_id(source);
|
|
|
|
bool ft2 = strcmp(id, "text_ft2_source") == 0;
|
|
|
|
bool read_from_file = obs_data_get_bool(
|
|
|
|
settings, ft2 ? "from_file" : "read_from_file");
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease font_obj = obs_data_get_obj(settings, "font");
|
2018-08-23 20:43:44 -05:00
|
|
|
MakeQFont(font_obj, font);
|
|
|
|
|
2021-09-19 21:44:34 +02:00
|
|
|
// Use "color1" if it's a freetype source and "color" elsewise
|
|
|
|
unsigned int val = (unsigned int)obs_data_get_int(
|
|
|
|
settings,
|
|
|
|
(strncmp(obs_source_get_id(source), "text_ft2_source", 15) == 0)
|
|
|
|
? "color1"
|
|
|
|
: "color");
|
|
|
|
|
2018-08-23 20:43:44 -05:00
|
|
|
color = color_from_int(val);
|
|
|
|
|
|
|
|
const char *text = obs_data_get_string(settings, "text");
|
|
|
|
|
|
|
|
bool single_line = !read_from_file &&
|
|
|
|
(!text || (strchr(text, '\n') == nullptr));
|
|
|
|
ui->emptySpace->setVisible(!single_line);
|
|
|
|
ui->text->setVisible(single_line);
|
|
|
|
if (single_line)
|
|
|
|
ui->text->setText(text);
|
|
|
|
}
|
|
|
|
|
2022-02-17 08:33:56 -06:00
|
|
|
TextSourceToolbar::~TextSourceToolbar() {}
|
2018-08-23 20:43:44 -05:00
|
|
|
|
|
|
|
void TextSourceToolbar::on_selectFont_clicked()
|
|
|
|
{
|
|
|
|
OBSSource source = GetSource();
|
|
|
|
if (!source) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
QFontDialog::FontDialogOptions options;
|
|
|
|
uint32_t flags;
|
|
|
|
bool success;
|
|
|
|
|
|
|
|
#ifndef _WIN32
|
|
|
|
options = QFontDialog::DontUseNativeDialog;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
font = QFontDialog::getFont(&success, font, this, "Pick a Font",
|
|
|
|
options);
|
|
|
|
if (!success) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease font_obj = obs_data_create();
|
2018-08-23 20:43:44 -05:00
|
|
|
|
|
|
|
obs_data_set_string(font_obj, "face", QT_TO_UTF8(font.family()));
|
|
|
|
obs_data_set_string(font_obj, "style", QT_TO_UTF8(font.styleName()));
|
|
|
|
obs_data_set_int(font_obj, "size", font.pointSize());
|
|
|
|
flags = font.bold() ? OBS_FONT_BOLD : 0;
|
|
|
|
flags |= font.italic() ? OBS_FONT_ITALIC : 0;
|
|
|
|
flags |= font.underline() ? OBS_FONT_UNDERLINE : 0;
|
|
|
|
flags |= font.strikeOut() ? OBS_FONT_STRIKEOUT : 0;
|
|
|
|
obs_data_set_int(font_obj, "flags", flags);
|
|
|
|
|
2021-03-22 01:46:46 -04:00
|
|
|
SaveOldProperties(source);
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_data_create();
|
2018-08-23 20:43:44 -05:00
|
|
|
|
|
|
|
obs_data_set_obj(settings, "font", font_obj);
|
|
|
|
|
|
|
|
obs_source_update(source, settings);
|
2021-03-22 01:46:46 -04:00
|
|
|
|
|
|
|
SetUndoProperties(source);
|
2018-08-23 20:43:44 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void TextSourceToolbar::on_selectColor_clicked()
|
|
|
|
{
|
|
|
|
OBSSource source = GetSource();
|
|
|
|
if (!source) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2021-09-19 21:44:34 +02:00
|
|
|
bool freetype =
|
|
|
|
strncmp(obs_source_get_id(source), "text_ft2_source", 15) == 0;
|
|
|
|
|
|
|
|
obs_property_t *p =
|
|
|
|
obs_properties_get(props.get(), freetype ? "color1" : "color");
|
|
|
|
|
2018-08-23 20:43:44 -05:00
|
|
|
const char *desc = obs_property_description(p);
|
|
|
|
|
|
|
|
QColorDialog::ColorDialogOptions options;
|
|
|
|
|
2021-09-19 19:18:26 +02:00
|
|
|
options |= QColorDialog::ShowAlphaChannel;
|
2018-08-23 20:43:44 -05:00
|
|
|
#ifndef _WIN32
|
|
|
|
options |= QColorDialog::DontUseNativeDialog;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
QColor newColor = QColorDialog::getColor(color, this, desc, options);
|
|
|
|
if (!newColor.isValid()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
color = newColor;
|
|
|
|
|
2021-03-22 01:46:46 -04:00
|
|
|
SaveOldProperties(source);
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_data_create();
|
2021-09-19 21:44:34 +02:00
|
|
|
if (freetype) {
|
2020-08-31 21:58:12 +10:00
|
|
|
obs_data_set_int(settings, "color1", color_to_int(color));
|
|
|
|
obs_data_set_int(settings, "color2", color_to_int(color));
|
|
|
|
} else {
|
|
|
|
obs_data_set_int(settings, "color", color_to_int(color));
|
|
|
|
}
|
2018-08-23 20:43:44 -05:00
|
|
|
obs_source_update(source, settings);
|
2021-03-22 01:46:46 -04:00
|
|
|
|
|
|
|
SetUndoProperties(source);
|
2018-08-23 20:43:44 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void TextSourceToolbar::on_text_textChanged()
|
|
|
|
{
|
|
|
|
OBSSource source = GetSource();
|
|
|
|
if (!source) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2021-11-05 21:42:41 +01:00
|
|
|
SaveOldProperties(source);
|
|
|
|
|
2021-11-26 22:25:39 +13:00
|
|
|
OBSDataAutoRelease settings = obs_data_create();
|
2018-08-23 20:43:44 -05:00
|
|
|
obs_data_set_string(settings, "text", QT_TO_UTF8(ui->text->text()));
|
|
|
|
obs_source_update(source, settings);
|
2021-11-05 21:42:41 +01:00
|
|
|
|
|
|
|
SetUndoProperties(source, true);
|
2018-08-23 20:43:44 -05:00
|
|
|
}
|