Hello, Everybody, I am back!
I have finished an 'alpha' version of the SVG demo program that complies with the new websocket protocol (RFC6455). Below is a rough list of release notes, along with a 'to do' list that I will be working on in the coming weeks.
Changes:
1. Changed the handshake and websocket read/write VI's to conform to the RFC6455 version of the websocket protocol currently supported by Chrome 16.
2. Replaced the string indicator on the main front panel with a dialog that pops up when a message is received from the client (from clicking the buttons and switch on the SVG document.
3. Tested the demo with Chrome version 16.0.912.75 m. Seems to work OK so far. If you find bugs, let me know. I did not test the script and program with any other browser. I use Chrome exclusively, with the intention of using this system with Android tablets and Chrome OS. I do not currently own a tablet, so if anyone tests it, please
4. Cleaned up the folder system for the project and got rid of the RGraph library demo, as well as a bunch of other files that were not used and cluttering up the folders. I will no longer be working with the RGraph library, and will instead focus on the webpanel library.
As with the previous version, open the WebPanel project and the SVGDemo VI. Run the VI, then open the \www\WebPanelTest.svg file on the same computer. It should connect to the listener and begin updating.
Disclaimer:
Please test and use the library however you wish. No warranty is implied, and I am not responsible for anything that happens as a result of using this code. Downloading the file acknowledges this disclaimer.
WPLavaG.zip
LabVIEW 2009 or later is required. Please contact me for earlier versions (will need 8.5 min due to the use of classes).
My to do list (not necessarily in the order presented here)
1. Change my web host to a suitable provider and migrate the files to a subversion directory.
2. Rework the websocket Labview Class and add dynamic dispatching to accomodate future revisions of the websocket protocol
3. Change the SVG namespace of the webpanel objects to shorten the name.
4. Clean up and document the ecmascript file and look at new methods of controlling the objects.
5. Document the SVG elements and create new objects.
6. Fully document everything in a PDF file, with commentary on methodology
7. Create new website with documentation and file download area.
8. Offer the package to OpenG.org
9. Change the protocol to binary
10. Migrate the ecmascript engine to open source.
Please post your comments/questions on this version here, or message me privately if you wish. Thanks, everyone, and happy SVG'ing.
I should also note the LabVIEW side of the demo does not cleanly close the websocket on shutdown, as I have not yet added any control frames to the new protocol. Also,in case you missed it, while the new protocol supports binary, I opted for text so I wouldn't have to make any changes to the javascript. Obviously, binary is a better choice, but that is down the road because it will require the data parsing portion of the script to be overhauled. I also want to spend some time thinking about what the binary protocol should look like. Any thoughts on this subject are welcome. I hope to have the new website up and running sometime before the end of Feb.