Git Product home page Git Product logo

pyg5's Introduction

PyG5

CI

Description

This project aims at development a Garmin G5 view targeting a Raspberry Pi 7 inches display (640x480) . The intent is to provide a G5 Attitude indicator + G5 Horizontal Situation Indicator stacked on the display in vertical mode. The pyG5 connects to X-Plane flight simulator.

It does not require any plugin and use the standard DREF UDP interface from X-Plane. It should not require any configuration. Start it and it will connect to X-Plane and fetch the required data.

This is currently developed on macOS with python 3.9 and testing on a Raspberry Pi 4 with Raspberry Pi OS and an official 7 inches display in vertical mode.

Below is a view of the user interface.

demoView

And you can see it in its simulation environment

flightSimView

Maturity

It's currently in pretty early phase. It's functional and should be easy to install but might suffer from issues here and there.

Not all the features of the G5 are implemented. It's currently missing:

  • Glide scope
  • lateral guidance on the AI
  • Distance to next way point on the Horizontal Situation Indicator.

Installation

pyG5 depends on pySide6. Due to failure to install pySide6 from pip on Raspberry Pi OS it is not a dependency of the pyG5. As a result it needs to be installed manually.

        > sudo pip3 install pyside6

The install PyG5:

        > sudo pip3 install pyG5

Running

        > pyG5DualStacked

Running on Raspberry Pi it is recommended to install FreeSans fonts in order to be consistent with the rendering on the current main development platform, ie. macOS. Most liked this is solved with:

        > sudo apt-get install libfreetype6

Developers

If you intend to develop based on this project. At a glance:

  • The application runs on PyQt5 event loop.
  • It's loosely implementing a Model View Controller coding style
  • The pyG5Network contains X-Plane network interface is monitoring the connection and feed data at 30Hz to a slot
  • The view is repainting the interface every time the data is received from the network interface
  • The pyG5Widget is derived twice into and Horizontal Situation Indicator and an AI. the pyG5DualStack instantiate both into a single widget. That means it's easy to build the view with just one of them.
  • The pyG5Main module contains the application and the main window class.

Running from sources

Clone the repository

        > git clone 

Initialize the virtual environment

        > source bootstrap.sh

Start the Application

        > python -m pyG5.pyG5Main

In order to evaluate the design without X-Plane running you can use:

        > python -m pyG5.pyG5ViewTester

This will feed the data from the sliders in the UI instead of the X-Plane network interface:

ViewTester

License

License files

pyg5's People

Contributors

blauret avatar crazyknightgr avatar timsschoen avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.