mirror of
https://github.com/Almamu/linux-wallpaperengine.git
synced 2025-07-14 05:12:25 +08:00
Added parameter to configure fullscreen detection
Signed-off-by: Alexis Maiquez <almamu@almamu.com>
This commit is contained in:
parent
9a5913921c
commit
13e43bada7
@ -26,6 +26,7 @@ struct option long_options[] = {
|
||||
{ "list-properties", no_argument, nullptr, 'l' },
|
||||
{ "set-property", required_argument, nullptr, 'o' },
|
||||
{ "noautomute", no_argument, nullptr, 'm' },
|
||||
{ "no-fullscreen-pause", no_argument,nullptr, 'n' },
|
||||
{ nullptr, 0, nullptr, 0 }
|
||||
};
|
||||
|
||||
@ -62,6 +63,7 @@ CApplicationContext::CApplicationContext (int argc, char* argv[])
|
||||
{
|
||||
.mode = NORMAL_WINDOW,
|
||||
.maximumFPS = 30,
|
||||
.pauseOnFullscreen = true,
|
||||
.window = { .geometry = {}},
|
||||
},
|
||||
.audio =
|
||||
@ -82,105 +84,110 @@ CApplicationContext::CApplicationContext (int argc, char* argv[])
|
||||
|
||||
std::string lastScreen;
|
||||
|
||||
while ((c = getopt_long (argc, argv, "b:r:p:d:shf:a:w:m", long_options, nullptr)) != -1)
|
||||
while ((c = getopt_long (argc, argv, "b:r:p:d:shf:a:w:mn", long_options, nullptr)) != -1)
|
||||
{
|
||||
switch (c)
|
||||
{
|
||||
case 'b':
|
||||
if (lastScreen.empty ())
|
||||
sLog.exception ("--bg has to go after a --screen-root argument");
|
||||
case 'n':
|
||||
this->settings.render.pauseOnFullscreen = false;
|
||||
break;
|
||||
|
||||
// no need to check for previous screen being in the list, as it's the only way for this variable
|
||||
// to have any value
|
||||
this->settings.general.screenBackgrounds[lastScreen] = translateBackground (optarg);
|
||||
break;
|
||||
case 'b':
|
||||
if (lastScreen.empty ())
|
||||
sLog.exception ("--bg has to go after a --screen-root argument");
|
||||
|
||||
case 'o':
|
||||
{
|
||||
std::string value = optarg;
|
||||
std::string::size_type equals = value.find ('=');
|
||||
// no need to check for previous screen being in the list, as it's the only way for this variable
|
||||
// to have any value
|
||||
this->settings.general.screenBackgrounds[lastScreen] = translateBackground (optarg);
|
||||
break;
|
||||
|
||||
// properties without value are treated as booleans for now
|
||||
if (equals == std::string::npos)
|
||||
this->settings.general.properties[value] = "1";
|
||||
else
|
||||
this->settings.general.properties[value.substr (0, equals)] = value.substr (equals + 1);
|
||||
}
|
||||
break;
|
||||
case 'o':
|
||||
{
|
||||
std::string value = optarg;
|
||||
std::string::size_type equals = value.find ('=');
|
||||
|
||||
case 'l':
|
||||
this->settings.general.onlyListProperties = true;
|
||||
break;
|
||||
// properties without value are treated as booleans for now
|
||||
if (equals == std::string::npos)
|
||||
this->settings.general.properties[value] = "1";
|
||||
else
|
||||
this->settings.general.properties[value.substr (0, equals)] = value.substr (equals + 1);
|
||||
}
|
||||
break;
|
||||
|
||||
case 'r':
|
||||
if (this->settings.general.screenBackgrounds.find (optarg) != this->settings.general.screenBackgrounds.end ())
|
||||
sLog.exception ("Cannot specify the same screen more than once: ", optarg);
|
||||
if (this->settings.render.mode == EXPLICIT_WINDOW)
|
||||
sLog.exception ("Cannot run in both background and window mode");
|
||||
case 'l':
|
||||
this->settings.general.onlyListProperties = true;
|
||||
break;
|
||||
|
||||
this->settings.render.mode = X11_BACKGROUND;
|
||||
lastScreen = optarg;
|
||||
this->settings.general.screenBackgrounds[lastScreen] = "";
|
||||
break;
|
||||
case 'r':
|
||||
if (this->settings.general.screenBackgrounds.find (optarg) != this->settings.general.screenBackgrounds.end ())
|
||||
sLog.exception ("Cannot specify the same screen more than once: ", optarg);
|
||||
if (this->settings.render.mode == EXPLICIT_WINDOW)
|
||||
sLog.exception ("Cannot run in both background and window mode");
|
||||
|
||||
case 'w':
|
||||
if (this->settings.render.mode == X11_BACKGROUND)
|
||||
sLog.exception ("Cannot run in both background and window mode");
|
||||
this->settings.render.mode = X11_BACKGROUND;
|
||||
lastScreen = optarg;
|
||||
this->settings.general.screenBackgrounds[lastScreen] = "";
|
||||
break;
|
||||
|
||||
if (optarg != nullptr)
|
||||
{
|
||||
this->settings.render.mode = EXPLICIT_WINDOW;
|
||||
// read window geometry
|
||||
char* pos = optarg;
|
||||
case 'w':
|
||||
if (this->settings.render.mode == X11_BACKGROUND)
|
||||
sLog.exception ("Cannot run in both background and window mode");
|
||||
|
||||
if (pos != nullptr)
|
||||
this->settings.render.window.geometry.x = atoi (pos);
|
||||
if ((pos = strchr (pos, 'x')) != nullptr)
|
||||
this->settings.render.window.geometry.y = atoi (pos + 1);
|
||||
if ((pos = strchr (pos + 1, 'x')) != nullptr)
|
||||
this->settings.render.window.geometry.z = atoi (pos + 1);
|
||||
if ((pos = strchr (pos + 1, 'x')) != nullptr)
|
||||
this->settings.render.window.geometry.w = atoi (pos + 1);
|
||||
}
|
||||
break;
|
||||
if (optarg != nullptr)
|
||||
{
|
||||
this->settings.render.mode = EXPLICIT_WINDOW;
|
||||
// read window geometry
|
||||
char* pos = optarg;
|
||||
|
||||
case 'p':
|
||||
case 'd':
|
||||
sLog.error ("--dir/--pkg is deprecated and not used anymore");
|
||||
this->settings.general.defaultBackground = translateBackground (stringPathFixes (optarg));
|
||||
break;
|
||||
if (pos != nullptr)
|
||||
this->settings.render.window.geometry.x = atoi (pos);
|
||||
if ((pos = strchr (pos, 'x')) != nullptr)
|
||||
this->settings.render.window.geometry.y = atoi (pos + 1);
|
||||
if ((pos = strchr (pos + 1, 'x')) != nullptr)
|
||||
this->settings.render.window.geometry.z = atoi (pos + 1);
|
||||
if ((pos = strchr (pos + 1, 'x')) != nullptr)
|
||||
this->settings.render.window.geometry.w = atoi (pos + 1);
|
||||
}
|
||||
break;
|
||||
|
||||
case 's':
|
||||
this->settings.audio.enabled = false;
|
||||
break;
|
||||
case 'p':
|
||||
case 'd':
|
||||
sLog.error ("--dir/--pkg is deprecated and not used anymore");
|
||||
this->settings.general.defaultBackground = translateBackground (stringPathFixes (optarg));
|
||||
break;
|
||||
|
||||
case 'h':
|
||||
printHelp (argv[0]);
|
||||
break;
|
||||
case 's':
|
||||
this->settings.audio.enabled = false;
|
||||
break;
|
||||
|
||||
case 'f':
|
||||
this->settings.render.maximumFPS = atoi (optarg);
|
||||
break;
|
||||
case 'h':
|
||||
printHelp (argv[0]);
|
||||
break;
|
||||
|
||||
case 'a':
|
||||
this->settings.general.assets = stringPathFixes (optarg);
|
||||
break;
|
||||
case 'f':
|
||||
this->settings.render.maximumFPS = atoi (optarg);
|
||||
break;
|
||||
|
||||
case 'v':
|
||||
this->settings.audio.volume = std::max (atoi (optarg), 128);
|
||||
break;
|
||||
case 'a':
|
||||
this->settings.general.assets = stringPathFixes (optarg);
|
||||
break;
|
||||
|
||||
case 'c':
|
||||
this->settings.screenshot.take = true;
|
||||
this->settings.screenshot.path = stringPathFixes (optarg);
|
||||
break;
|
||||
case 'v':
|
||||
this->settings.audio.volume = std::max (atoi (optarg), 128);
|
||||
break;
|
||||
|
||||
case 'm':
|
||||
this->settings.audio.automute = false;
|
||||
break;
|
||||
default:
|
||||
sLog.out ("Default on path parsing: ", optarg);
|
||||
break;
|
||||
case 'c':
|
||||
this->settings.screenshot.take = true;
|
||||
this->settings.screenshot.path = stringPathFixes (optarg);
|
||||
break;
|
||||
|
||||
case 'm':
|
||||
this->settings.audio.automute = false;
|
||||
break;
|
||||
|
||||
default:
|
||||
sLog.out ("Default on path parsing: ", optarg);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -272,4 +279,5 @@ void CApplicationContext::printHelp (const char* route)
|
||||
sLog.out ("\t--screenshot\t\t\t\tTakes a screenshot of the background");
|
||||
sLog.out ("\t--list-properties\t\t\tList all the available properties and their possible values");
|
||||
sLog.out ("\t--set-property <name=value>\tOverrides the default value of the given property");
|
||||
sLog.out ("\t--no-fullscreen-pause\tPrevents the background pausing when an app is fullscreen");
|
||||
}
|
@ -61,6 +61,8 @@ namespace WallpaperEngine::Application
|
||||
WINDOW_MODE mode;
|
||||
/** Maximum FPS */
|
||||
int maximumFPS;
|
||||
/** Indicates if pausing should happen when something goes fullscreen */
|
||||
bool pauseOnFullscreen;
|
||||
|
||||
struct
|
||||
{
|
||||
|
@ -273,7 +273,7 @@ namespace WallpaperEngine::Application
|
||||
// output requested
|
||||
WallpaperEngine::Render::Drivers::Output::COutput* output;
|
||||
// fullscreen detector is common for the different render modes
|
||||
WallpaperEngine::Render::Drivers::Detectors::CX11FullScreenDetector fullscreenDetector (videoDriver);
|
||||
WallpaperEngine::Render::Drivers::Detectors::CX11FullScreenDetector fullscreenDetector (this->m_context, videoDriver);
|
||||
// stereo mix recorder for audio processing
|
||||
WallpaperEngine::Audio::Drivers::Recorders::CPulseAudioPlaybackRecorder audioRecorder;
|
||||
// audio playing detector
|
||||
|
@ -1 +1,14 @@
|
||||
#include "CFullScreenDetector.h"
|
||||
|
||||
using namespace WallpaperEngine;
|
||||
using namespace WallpaperEngine::Render::Drivers::Detectors;
|
||||
|
||||
CFullScreenDetector::CFullScreenDetector (Application::CApplicationContext& appContext) :
|
||||
m_applicationContext (appContext)
|
||||
{
|
||||
}
|
||||
|
||||
Application::CApplicationContext& CFullScreenDetector::getApplicationContext () const
|
||||
{
|
||||
return this->m_applicationContext;
|
||||
}
|
@ -1,10 +1,14 @@
|
||||
#pragma once
|
||||
|
||||
#include "WallpaperEngine/Application/CApplicationContext.h"
|
||||
|
||||
namespace WallpaperEngine::Render::Drivers::Detectors
|
||||
{
|
||||
class CFullScreenDetector
|
||||
{
|
||||
public:
|
||||
CFullScreenDetector (Application::CApplicationContext& appContext);
|
||||
|
||||
/**
|
||||
* @return If anything is fullscreen
|
||||
*/
|
||||
@ -14,5 +18,12 @@ namespace WallpaperEngine::Render::Drivers::Detectors
|
||||
* Restarts the fullscreen detector, specially useful if there's any resources tied to the output driver
|
||||
*/
|
||||
virtual void reset () = 0;
|
||||
/**
|
||||
* @return The application context using this detector
|
||||
*/
|
||||
[[nodiscard]] Application::CApplicationContext& getApplicationContext () const;
|
||||
|
||||
private:
|
||||
Application::CApplicationContext& m_applicationContext;
|
||||
};
|
||||
}
|
@ -31,7 +31,8 @@ namespace WallpaperEngine::Render::Drivers::Detectors
|
||||
return 0;
|
||||
}
|
||||
|
||||
CX11FullScreenDetector::CX11FullScreenDetector (CVideoDriver& driver) :
|
||||
CX11FullScreenDetector::CX11FullScreenDetector (Application::CApplicationContext& appContext, CVideoDriver& driver) :
|
||||
CFullScreenDetector (appContext),
|
||||
m_driver (driver)
|
||||
{
|
||||
// do not use previous handler, it might stop the app under weird circumstances
|
||||
@ -51,6 +52,9 @@ namespace WallpaperEngine::Render::Drivers::Detectors
|
||||
|
||||
bool CX11FullScreenDetector::anythingFullscreen () const
|
||||
{
|
||||
if (!this->getApplicationContext ().settings.render.pauseOnFullscreen)
|
||||
return false;
|
||||
|
||||
// stop rendering if anything is fullscreen
|
||||
bool isFullscreen = false;
|
||||
XWindowAttributes attribs;
|
||||
|
@ -11,10 +11,10 @@
|
||||
|
||||
namespace WallpaperEngine::Render::Drivers::Detectors
|
||||
{
|
||||
class CX11FullScreenDetector : public CFullScreenDetector
|
||||
class CX11FullScreenDetector : public CFullScreenDetector
|
||||
{
|
||||
public:
|
||||
CX11FullScreenDetector (CVideoDriver& driver);
|
||||
CX11FullScreenDetector (Application::CApplicationContext& appContext, CVideoDriver& driver);
|
||||
~CX11FullScreenDetector ();
|
||||
|
||||
[[nodiscard]] bool anythingFullscreen () const override;
|
||||
|
Loading…
Reference in New Issue
Block a user