1
0
mirror of https://gitlab.com/kelteseth/ScreenPlay.git synced 2024-11-05 02:22:28 +01:00
ScreenPlay/Docs/ProjectOverview.md
2021-11-11 18:24:10 +01:00

2.7 KiB

Overview

ScreenPlay consists of 7 projects:

  1. ScreenPlay executable
    • The main ScreenPlay App UI with Create, Installed, Community and Settings.
  2. ScreenPlayWallpaper executable
    • The Wallpaper executable that is used for displaying a single wallpaper. This uses ScreenPlaySDK to talk via QLocalsockets with the main ScreenPlayApp.
  3. ScreenPlayWidget executable
    • The Widget executable that is used for displaying a single widget. This uses ScreenPlaySDK to talk via QLocalsockets with the main ScreenPlayApp.
  4. ScreenPlayUtil lib
    • Util function, like project.json loading, that are needed in ScreenPlay and Workshop plugin.
  5. ScreenPlaySDK lLib
    • A SDK used internally in the ScreenPlayWallpaper and ScreenPlayWidget to talk to the main ScreenPlay app via QLocalsockets (Windows Pipes and Unix sockets).
  6. ScreenPlaySysInfo lib
    • A qml plugin to read CPU, GPU, Network and all sort of statisitcs.
  7. ScreenPlayWorkshop plugin
    • The Steam workshop plugin that is loaded at runtime.

ProjectOverview.png

ScreenPlay App Class

ScreenPlay wrapps all classes into a App.h and App.cpp class. This is easier for unit test integration (not implemented yet!). The main app class is used for owning all other classes via Q_PROPERTY to be easily accessible in the GUI/QML. We use the constructor of the App class to initialize all Qt register types, fonts and to check if another ScreenPlay instance is running. The init() method is used to initialize all other c++ classes in a certain order! It also sets up some events signal/slots like when the user changes the UI language.

For all other class documentation please visit ScreenPlayDeveloperDocs

        graph TD

        Main.cpp --> App
        App --> QQmlApplicationEngine
        App --> GlobalVariables
        App --> ScreenPlayManager
        ScreenPlayManager --> ScreenPlayWallpaper
        ScreenPlayManager --> ScreenPlayWidget
        App --> Create
        Create--> CreateVideoImport
        App --> Util
        App --> Settings
        App --> SDKConnector
        App --> InstalledListModel
        InstalledListModel --> ProjectFile
        App --> InstalledListFilter
        App --> MonitorListModel
        MonitorListModel --> Monitor
        App --> ProfileListModel
        ProfileListModel --> Profile