Skip to content

Latest commit

 

History

History
33 lines (28 loc) · 2.52 KB

README.md

File metadata and controls

33 lines (28 loc) · 2.52 KB

hybrid-engine-ui

This repo contains the source code for the hybrid engine ground system UI

Setup

  1. (Only required if working on UI) Follow steps on InSpace wiki to apply for Qt educational license and install Qt tools https://imaginary-fennel-36b.notion.site/PyQt-9af8dcdfb79d4bae98e3848670bb9994
  2. Create a Python virtual environment python -m venv <virtual environment name>
  3. Activate the virtual environment
    • On Windows: Run .\<venv directory>\Scripts\Activate.ps1. Note that you made need modify your machines execution policy if on Windows 11. To do so, run Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser
    • On Linux/Mac: Run source <venv directory>\bin\activate
  4. Install the required dependencies by running pip install -r requirements.txt
  5. Build the UI either using custom build steps in Qt Creator or running the build script python build.py

Running

This application can be run either from the command line or in the Qt creator application. If running in Qt creator ensure that you have correctly added the custom build steps. To run this application from the command line run python main.py

Project structure

Here's a quick breakdown of the files and directories of this project

  • main.py - Entrypoint of project, creates and displays and instance of MainWindow. This is the only file that needs to be executed
  • build.py - Python script that compiles generated .ui and .qrc files
  • packet_spec.py - Contains implementation of the hybrid communications packet specification and related parsing functions
  • main_window - Contains code for user MainWindow interface
    • ui - Contains generated and compiled UI code and images
      • form.ui - Generated XML-like file representation of UI
      • ui_form.py - Compiled Python code of form.ui
      • resources.qrc - Generated file containing information of images and other assets
      • rc_resources.qrc - Compiled Python code of resources.qrc
    • main_window.py - Contains code for MainWindow class, primarily consists of imports from other files
    • udp.py - Contains all slots and handler code for UDP stuff
    • data_handlers.py - Contains all code for processing data
    • recording_and_playback.py - Contains all code for handling recording and playback of data
    • logging.py - Contains all code for handling logging