Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hcl-tech-software/traffic-light-web
A traffic light controller implemented in Model RealTime. Communicates with a web server for visualizing application behavior in a web application.
https://github.com/hcl-tech-software/traffic-light-web
model-realtime
Last synced: 8 days ago
JSON representation
A traffic light controller implemented in Model RealTime. Communicates with a web server for visualizing application behavior in a web application.
- Host: GitHub
- URL: https://github.com/hcl-tech-software/traffic-light-web
- Owner: HCL-TECH-SOFTWARE
- License: mit
- Created: 2018-10-26T13:57:25.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2024-03-28T11:33:34.000Z (9 months ago)
- Last Synced: 2024-12-20T12:15:46.468Z (16 days ago)
- Topics: model-realtime
- Language: JavaScript
- Homepage: https://www.hcl-software.com/devops-model-realtime
- Size: 261 KB
- Stars: 1
- Watchers: 2
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# traffic-light-web
A traffic light controller implemented in [DevOps Model RealTime](https://www.hcl-software.com/devops-model-realtime). Communicates with a web server (implemented in Node JS) for visualizing application behavior in a web application. Also shows how a web application can send messages to the C++ application.
Note: The communication with the web server uses the [lib-http-server](https://github.com/HCL-TECH-SOFTWARE/lib-http-server) library, so you must clone that repository also into your workspace.
## Starting the web server
* `cd webapp`* `npm install`
* `node app.js`
* Open [http://localhost:4000/](http://localhost:4000/) in a web browser
## Building and running the traffic light controller software
* Create an Eclipse workspace and import the project in the TrafficLightsDemo folder.
* Also import the project from the [lib-http-server](https://github.com/HCL-TECH-SOFTWARE/lib-http-server) library.
* Pick the transformation configuration (TC) that corresponds to your platform. TCs for Windows (Visual Studio 2017 and MinGW) and Raspbian (with GCC 6.0.3) are provided. If you want to build for another platform copy one of these TCs and update necessary properties (typically "TargetRTS configuration", "Make type" and "Make command").
* Update the chosen TC by setting the property `tc.pocoLoc` to the location of the POCO library.
* Build the TC by right-clicking on it and do **Build**. If you build for the Raspberry Pi you need to transfer the built executable to the Pi (the Eclipse Remote Systems Plugin can help with that).
* `cd \TrafficLightsDemo_target\default`
* If you have built POCO as shared libraries remember to set the PATH variable (on Windows) or LD\_LIBRARY\_PATH (on Unix) to include the folder where they are located. For 64 bit builds the folder is called 'bin64' and is in the POCO root folder.
* `executable.exe -URTS_DEBUG=quit -webhost= -webport=` where you should set `` and `` to where you run the web application.## How the application works
When started the application begins to cycle the traffic light from red to green to yellow and back to red again. This cycling is driven by a timer. When the application receives a request for a pedestrian to cross the street (it can for example be triggered by pressing the button in the web application), it will put the traffic light to the Red state. After a while it will then turn the pedestrian signal from Stop to Walk and then back to Stop. Finally it starts to cycle the traffic light again.
Each time the traffic light or pedestrian light changes state, a message is sent to the web application using an HTTP request. The web application in turn translates this into changing the graphics in the web application by sending a message over a web socket.