f53df7da64
Code submissions have continually suffered from formatting inconsistencies that constantly have to be addressed. Using clang-format simplifies this by making code formatting more consistent, and allows automation of the code formatting so that maintainers can focus more on the code itself instead of code formatting.
186 lines
5.3 KiB
C++
186 lines
5.3 KiB
C++
#include <QDragEnterEvent>
|
|
#include <QDragLeaveEvent>
|
|
#include <QDragMoveEvent>
|
|
#include <QDropEvent>
|
|
#include <QFileInfo>
|
|
#include <QMimeData>
|
|
#include <string>
|
|
|
|
#include "window-basic-main.hpp"
|
|
#include "qt-wrappers.hpp"
|
|
|
|
using namespace std;
|
|
|
|
static const char *textExtensions[] = {"txt", "log", nullptr};
|
|
|
|
static const char *imageExtensions[] = {"bmp", "tga", "png", "jpg",
|
|
"jpeg", "gif", nullptr};
|
|
|
|
static const char *htmlExtensions[] = {"htm", "html", nullptr};
|
|
|
|
static const char *mediaExtensions[] = {
|
|
"3ga", "669", "a52", "aac", "ac3", "adt", "adts", "aif",
|
|
"aifc", "aiff", "amb", "amr", "aob", "ape", "au", "awb",
|
|
"caf", "dts", "flac", "it", "kar", "m4a", "m4b", "m4p",
|
|
"m5p", "mid", "mka", "mlp", "mod", "mpa", "mp1", "mp2",
|
|
"mp3", "mpc", "mpga", "mus", "oga", "ogg", "oma", "opus",
|
|
"qcp", "ra", "rmi", "s3m", "sid", "spx", "tak", "thd",
|
|
"tta", "voc", "vqf", "w64", "wav", "wma", "wv", "xa",
|
|
"xm", "3g2", "3gp", "3gp2", "3gpp", "amv", "asf", "avi",
|
|
"bik", "crf", "divx", "drc", "dv", "evo", "f4v", "flv",
|
|
"gvi", "gxf", "iso", "m1v", "m2v", "m2t", "m2ts", "m4v",
|
|
"mkv", "mov", "mp2", "mp2v", "mp4", "mp4v", "mpe", "mpeg",
|
|
"mpeg1", "mpeg2", "mpeg4", "mpg", "mpv2", "mts", "mtv", "mxf",
|
|
"mxg", "nsv", "nuv", "ogg", "ogm", "ogv", "ogx", "ps",
|
|
"rec", "rm", "rmvb", "rpl", "thp", "tod", "ts", "tts",
|
|
"txd", "vob", "vro", "webm", "wm", "wmv", "wtv", nullptr};
|
|
|
|
static string GenerateSourceName(const char *base)
|
|
{
|
|
string name;
|
|
int inc = 0;
|
|
|
|
for (;; inc++) {
|
|
name = base;
|
|
|
|
if (inc) {
|
|
name += " (";
|
|
name += to_string(inc + 1);
|
|
name += ")";
|
|
}
|
|
|
|
obs_source_t *source = obs_get_source_by_name(name.c_str());
|
|
if (!source)
|
|
return name;
|
|
}
|
|
}
|
|
|
|
void OBSBasic::AddDropSource(const char *data, DropType image)
|
|
{
|
|
OBSBasic *main = reinterpret_cast<OBSBasic *>(App()->GetMainWindow());
|
|
obs_data_t *settings = obs_data_create();
|
|
obs_source_t *source = nullptr;
|
|
const char *type = nullptr;
|
|
QString name;
|
|
|
|
switch (image) {
|
|
case DropType_RawText:
|
|
obs_data_set_string(settings, "text", data);
|
|
#ifdef _WIN32
|
|
type = "text_gdiplus";
|
|
#else
|
|
type = "text_ft2_source";
|
|
#endif
|
|
break;
|
|
case DropType_Text:
|
|
#ifdef _WIN32
|
|
obs_data_set_bool(settings, "read_from_file", true);
|
|
obs_data_set_string(settings, "file", data);
|
|
name = QUrl::fromLocalFile(QString(data)).fileName();
|
|
type = "text_gdiplus";
|
|
#else
|
|
obs_data_set_bool(settings, "from_file", true);
|
|
obs_data_set_string(settings, "text_file", data);
|
|
type = "text_ft2_source";
|
|
#endif
|
|
break;
|
|
case DropType_Image:
|
|
obs_data_set_string(settings, "file", data);
|
|
name = QUrl::fromLocalFile(QString(data)).fileName();
|
|
type = "image_source";
|
|
break;
|
|
case DropType_Media:
|
|
obs_data_set_string(settings, "local_file", data);
|
|
name = QUrl::fromLocalFile(QString(data)).fileName();
|
|
type = "ffmpeg_source";
|
|
break;
|
|
case DropType_Html:
|
|
obs_data_set_bool(settings, "is_local_file", true);
|
|
obs_data_set_string(settings, "local_file", data);
|
|
name = QUrl::fromLocalFile(QString(data)).fileName();
|
|
type = "browser_source";
|
|
break;
|
|
}
|
|
|
|
if (!obs_source_get_display_name(type)) {
|
|
obs_data_release(settings);
|
|
return;
|
|
}
|
|
|
|
if (name.isEmpty())
|
|
name = obs_source_get_display_name(type);
|
|
source = obs_source_create(type,
|
|
GenerateSourceName(QT_TO_UTF8(name)).c_str(),
|
|
settings, nullptr);
|
|
if (source) {
|
|
OBSScene scene = main->GetCurrentScene();
|
|
obs_scene_add(scene, source);
|
|
obs_source_release(source);
|
|
}
|
|
|
|
obs_data_release(settings);
|
|
}
|
|
|
|
void OBSBasic::dragEnterEvent(QDragEnterEvent *event)
|
|
{
|
|
event->acceptProposedAction();
|
|
}
|
|
|
|
void OBSBasic::dragLeaveEvent(QDragLeaveEvent *event)
|
|
{
|
|
event->accept();
|
|
}
|
|
|
|
void OBSBasic::dragMoveEvent(QDragMoveEvent *event)
|
|
{
|
|
event->acceptProposedAction();
|
|
}
|
|
|
|
void OBSBasic::dropEvent(QDropEvent *event)
|
|
{
|
|
const QMimeData *mimeData = event->mimeData();
|
|
|
|
if (mimeData->hasUrls()) {
|
|
QList<QUrl> urls = mimeData->urls();
|
|
|
|
for (int i = 0; i < urls.size(); i++) {
|
|
QString file = urls.at(i).toLocalFile();
|
|
QFileInfo fileInfo(file);
|
|
|
|
if (!fileInfo.exists())
|
|
continue;
|
|
|
|
QString suffixQStr = fileInfo.suffix();
|
|
QByteArray suffixArray = suffixQStr.toUtf8();
|
|
const char *suffix = suffixArray.constData();
|
|
bool found = false;
|
|
|
|
const char **cmp;
|
|
|
|
#define CHECK_SUFFIX(extensions, type) \
|
|
cmp = extensions; \
|
|
while (*cmp) { \
|
|
if (strcmp(*cmp, suffix) == 0) { \
|
|
AddDropSource(QT_TO_UTF8(file), type); \
|
|
found = true; \
|
|
break; \
|
|
} \
|
|
\
|
|
cmp++; \
|
|
} \
|
|
\
|
|
if (found) \
|
|
continue;
|
|
|
|
CHECK_SUFFIX(textExtensions, DropType_Text);
|
|
CHECK_SUFFIX(htmlExtensions, DropType_Html);
|
|
CHECK_SUFFIX(imageExtensions, DropType_Image);
|
|
CHECK_SUFFIX(mediaExtensions, DropType_Media);
|
|
|
|
#undef CHECK_SUFFIX
|
|
}
|
|
} else if (mimeData->hasText()) {
|
|
AddDropSource(QT_TO_UTF8(mimeData->text()), DropType_RawText);
|
|
}
|
|
}
|