• Stars
    star
    137
  • Rank 266,121 (Top 6 %)
  • Language
    C++
  • License
    Other
  • Created almost 12 years ago
  • Updated over 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

OpenFrameworks addon serves any number of variables (bool, float, int, enum, string, ofColor) on the network, so that you can modify from outside the OF app. Includes a native OSX Client. OSC based.

ofxRemoteUI

Build Status Build status

OpenFrameworks addon that allows you to serve c++ variables/parameters (bool, float, int, enum, string, ofColor) on the network, so that you can modify them remotely. It uses server client architecture, where your app is the server. It communicates both ways; you can modify your project's variables from the client, but you can also pull your app's variable values from the client; this way you can track values that evolve programatically. It runs on OSC.

You can save and then load "presets", which allow you to quickly change values for a lot of your parameters quickly. You can also make "group presets" to change only the values of a subset of your parameters.

Compile against OF master branch. If you are trying to use this against an older version (0.9.8 or lower) you should use the commit tagged with "OF_0.9.8". It requires ofxPoco in OF versions >0.9.8

Watch a quick Intro Video.

Clients
In order of appearance in the screenshot above, Mac OS X native Client, Built In Client (inside your OpenFrameworks app), Web Client (served from your OpenFrameworks app), iOS Client (not quite flushed out).


Features

  • Edit & Track variables remotely through UDP/OSC (bool, int, float, string, Enum, ofColor).
  • Allows to save/load your variable states across app launches.
  • MIDI and Joystick controller bindings. Bind any parameter to any MIDI controller knob/slider/note or HID Joystick. (OSX Client)
  • Parameter values are saved in your app's data folder, in xml format.
  • Allows creation/deletion of Presets, variable states that you can switch from and to quickly.
  • Presets can be created globally (saving all parameter values at once), or for a subset of params (param group).
  • Easily create Parameter Groups, and access them through keyboard shortcuts (OSX Client).
  • Parameter Groups are automatically colorized to easily identify them.
  • Realtime Filter your params by name to find things quickly (OSX Client).
  • Automatic discovery of servers in the network; easily control multiple apps from one Client interface.
  • Press "tab" on your OF app to see/edit your params from within your OF app. Allows you to do quick client-less edits; and also load and save Global and Group Presets.
  • Event notifications in both OSX client (through growl) and on your OF app.
  • You can always restore your parameters to the "previous launch" state, or to the default values.
  • Log remotely - ofxRemoteUIServer allows you to log messages to you client with RUI_LOG(); which accepts printf-like formatted writing.
  • ofxRemoteUI can be used outside OF in any C++ project, and in Processing thx to @kritzikratzi
  • Easy to use C++ Macros hide complexity away, very easy to plug into any existing project.
  • Support for native ofParameters of compatible types (int, float, bool, string ofColor, ofVec). Allows you to edit native OF ofParameter types from RemoteUI. See "example-ofParameter". *outdated!
  • Control parameters from any web browser through its web gui.

Dependencies

  • ofxXmlSettings
  • ofxOsc
  • ofxPoco in OperFrameworks version > 0.9.8

Available Clients

  • Native OSX client, feature complete (this should be your first choice)
  • Built in client (inside the OF app) for basic edits, saving, resetting, and global and group preset loading and saving.
  • WebClient based on dat.GUI. Connect to OpenFrameworks through websockets (thx to @jackosx).
  • Native iOS client (WIP - OSC is not very reliable over WIFI and only basic features implemented - deprecated).

Compatibility

Works in OpenFrameworks, but also in plain C++ projects. @kitschpatrol is actively working on a Cinder Block that works on top of a fork here. He's added some awesome feature like getter/setter support for your params, and maybe one day we'll be able to merge back.

There's also a feature limited version of the server for Processing, made by @kritzikratzi! See here.

Motivations

I know there's tons of very good UI's already, but one thing that bothers me about most of them is how by using them, your are affecting your framerates quite a lot. That's the main reason that made me build ofxRemoteUI. Being quite comfy in OSX development, I chose to make a full-featured native OSX client; although clients for other platforms could be developed as well, using the underlying ofxRemoteUIClient class.

Details

It's OSC based, and it includes a native OSX Client. The Native OSX Client allows param colorization for better clarity, and live param filtering. It also supports the grouping of params into categories, for easy access. There's automatic keyboard shortcuts to do so.

It can also be set to store the current values when quitting the app (or whenever its convenient), so that you can carry on where you left off last time you used it. It does so by saving a file called "ofxRemoteUISettings.xml" in your data folder. It uses ofxXmlSettings to store everything.

You can also create and delete presets, which are parameter states for your app. Presets are stored with your OF app, inside an "ofxRemoteUIPresets" folder, in your data folder. This makes it easy to check in your presets with your source code. Whenever you like the current config, you can make a preset to keep it around. You can also delete presets.

ofxRemoteUI uses Macros + the singleton pattern to make it very easy to share any variable you decide to edit remotely, from any class of your project.

The OSX client also allows to copy all the current params as plain text. You can also paste them back after editing them! Thx to @kritzikratzi for this idea!

To use it outside of OpenFrameworks, you can see how the example-noOF is setup.


How To Use

the most basic setup only requires a few calls.

float x;
int y;
ofColor color;

void setup(){

	RUI_SETUP(); //start server

	//Expose x and y vars to the server, providing a valid slider range
	RUI_SHARE_PARAM(x, 0, ofGetWidth());
	RUI_SHARE_PARAM(y, 0, ofGetHeight());

	//share the color param
	RUI_SHARE_COLOR_PARAM(color);

	//load values from XML, as they were last saved (if they were)
	RUI_LOAD_FROM_XML();
}

Then, use any of the client options to view and edit your shared parameters. Look into the server example to see more features. It is fairly documented.

Controller Bindings

The ofxRemoteUI OSX client allows to bind any midi control / joystick axis / button to any of your params. Make sure your device is connected before you launch the app. To bind a device to a parameter, do the following:

  1. Click on a param name on the main Window. It will start blinking.
  2. Rotate/Slide/Press your external device control (joystick, gamepad button, midi slider, knob, etc).
  3. Done! You can now control that param from your external controller

You can Save/Load/Edit/Clear your midi bindings from the "MIDI Bindings" window.

MIDI Sliders/Knobs/etc can be bound to floats, ints, enums, bools and colors. For ints, floats and enums, the mapping is obvious; for bools, the lower half of a slider/knob sets the param to false, the upper half to true. For colors, the slider shifts the hue of the color parameter.

Bools can also be bound to "piano keys"; params being set to true for as long as a key is held down.

Bindings are saved when the app is quit. You can also save any particular device binding configuration into a ".midiBind" file. You can also double-click any .midiBind file form the finder to load your previously saved bindings. There is a "bindings" window that allows you to delete particular bindings. You can see what parameters are currently bound by choosing "File->Blink Bound Midi Controls".

Web-based Interface

The web client allows you to control the parameters of your OpenFrameworks app from a web browser. It does so by connecting your web browser to your OF app through websockets; it uses ofxPoco to handle the connection.

ofxRemoteUIServer creates a minimal webserver that hosts a single-file HTML + JS + CSS gzipped package that your browser will interpret. You don't need to provide additional files.

You can quickly load up the web GUI interface by getting into the built-in client (press 'tab' from the OF app), and from there press 'c' (for client). This will launch a web browser and load the web gui for you.

The web interface is developed in a separate repository ofxRemoteUI-Web. The whole interface is packaged in the RUIWebBinary.cpp file, so if you want to modify / tweak the interface, go to the ofxRemoteUI-Web repo and create a new build of that file and drop it into the ofxRemoteUI src folder (replacing the old one).

The web client has completely been developed by @jackosx, with some quality-of-life tweaks by @armadillu.

Note that this interface is not very tested. Don't use several clients at the same time, only one will be alloewd to connect. Web client connection/disconnection doesnt seem very realiable at the moment, but should be ok for a quick edit. You can completely disable the web interface by defining the preprocessor macro "NO_RUI_WEB_INTERFACE" in your project.

Random Notes

"Restore to initial XML Values" sets alls params to whatever values they had at server app launch.
"Restore to Default Values" sets alls params to whatever values the shared variable had before sharing it with RUI_SHARE_PARAM().

Enums must be consecutive so that each enum item is +1 the previous one for them to work. This is usually the default c++ behavior if you don't set specific values when defining your enums. Break this rule and you will get crashes.

When loading a preset, it might be that the preset doesn't specify values for all your current params (because it was created when that param didn't exist). If so, the params whose values haven't been modified by the preset will show a small warning sign for a few seconds, so that you are aware.

Automatic discovery relies on each server advertising itself (its hostname, app name and port) on port 25748 over OSC.

There is a setting in the OSX client that allows for it to automatically connect to a server app when it launches in the local network, or only on your local computer. Look into the OSX Client preferences window.

RUI_SETUP() assigns a random port the first time the app is launched, and it uses that same port on successive launches. You can also manually specify a port by supplying it RUI_SETUP(10000);

ofxRemoteUIServer listens for the keyDown event, and if "tab" is pressed, it displays a built-in client with some basic features. You can interact with the built-in client using arrow keys, return, and some other keystrokes depending on the context. Read the on-screen help at the bottom.

The built-in UI can be set to draw in any scale (useful for retina screens) by using:

RUI_GET_INSTANCE()->setBuiltInUiScale(scale);

You can set the built-in UI to be drawn using ofxFontStash by adding it to your project, and defining USE_OFX_FONTSTASH in your project's PreProcessor Macros. This allows you to use any font to draw the built-in client ui by calling, instead of the default OF bitmap font.

RUI_GET_INSTANCE()->drawUiWithFontStash("myFont.ttf");

The same thing applies to ofxFontStash2.

XML FILE FORMAT

Commits before the Git Tag "LastCommitWithXMLv1" use the original file format for XML files. Commits after that tag, will automatically save in the new format (v2), but will also parse files with the old format. You can also save files in the old format by pressing "E" (for export) from the built in client, either globally or on a per-group basis.

The new file format is proper XML with a root node, it's more human readable, it keeps params listed in the same order they are added in so its easier to read changes on versioning systems, and it has comments showing the group they belong to.

g

LICENSE and ATTRIBUTIONS

ofxRemoteUI is made available under the MIT license.

The OSX Client uses the vvMidi frameworks to handle MIDI devices more easily. VVMidi uses a LGPL license.

The OSX Client's HID capabilities come mostly from @jotapeh.

ofxRemoteUI bundles ofxXmlSettings and ofxOSC from OpenFrameworks to allow non-OF C++ projects to use ofxRemoteUI.

More Repositories

1

ofxAnimatable

Set of classes that help setup very simple animations, with curves, repeat modes and barebones scheduling.
C++
115
star
2

ofxTimeMeasurements

OpenFrameworks add-on to easily measure execution times on different parts of your code.
C++
94
star
3

ofxFontStash

Easy (and fast) unicode string rendering addon for OpenFrameworks. FontStash is made by Andreas Krinke and Mikko Mononen
C
89
star
4

ofxHistoryPlot

Visualize value history on a configurable graph
C++
41
star
5

ofxFontStash2

OpenFrameworks FontStash wrapper
C
39
star
6

ofxTurboJpeg

Rough OF addon that uses turbo-jpeg lib to read and write jpegs. 2-3 times faster than OF's freeImage based jpeg en/decoder
C
33
star
7

ofxSimpleHttp

OpenFrameworks add-on to make http and https downloads easy
C
29
star
8

ofxSceneManager

ofxSceneManager helps handle different scenes and simple fade-to-black transitions between them.
C++
25
star
9

ofxFboBlur

blur shader
C++
23
star
10

ofxMapRouting

A* path finding for OF, tweaked for performance and small memory footprint - tweaks allowing to go for faster to process (but sub-optimal) paths
C++
19
star
11

ofxScreenSetup

OF addon to control window / fullscreen different modes
C++
18
star
12

ofxGoogleAnalytics

OpenFrameworks addon to track Screens/Events/Exceptions on Google Analytics using their Measurement Protocol Developer Guide
C++
17
star
13

ofxPanZoom

Simple OpenFrameworks add-on that handles Zooming and Panning on iDevices, allowing to explore 2D space.
Objective-C++
17
star
14

ofxEasyRetina

OF addon to enable retina graphics on iOS app without modifying the original appearance.
Objective-C
16
star
15

ofxWorkQueues

Easily distribute work on other threads - not safe - do not use!
C++
16
star
16

ofxHttpForm

OpenFrameworks addon to handle basic http forms
C++
15
star
17

ofxFastIOImage

load / save ofImages byte-to-byte as binary files, faster than ofImage load / save
C++
14
star
18

ofxColorGradient

Simple of addon to create linear color gradients
C++
14
star
19

ofxCenteredTrueTypeFont

simple ofTrueTypeFont subclass that allows to draw text centered around a point
C++
14
star
20

ofxTextureAtlas

texture atlas for OpenFrameworks
C++
13
star
21

ofxMidiFighterTwister

Communicate a Midi Fighter Twister MIDI controller with OpenFrameworks
C++
13
star
22

ofxGLFWJoystick

Use Joysticks in OpenFrameworks (GLFW window only)
C++
12
star
23

ofxImageMask

apply masks to ofImages at ofPixel level
C++
10
star
24

ofxOscRecorder

Record and playback ofxOsc streams
C++
10
star
25

ofxPhilipsHue

OpenFrameworks addon to control philips hue light bulbs
C++
9
star
26

ofxScreenCurtain

Use it to handle "fade to black" situations... Think of it as a theater curtain on your screen.
C++
8
star
27

ofxPsdLoad

OpenFramorks addon to load PSD files to ofPixels or ofTexture
C
8
star
28

ofxDXT

Use DXT texture compression with OpenFrameworks
C
8
star
29

ofxThreadedVideoPlayer

OSX video playback addon based on ofxAVFVideoPlayer. Allows to load movies on the fly in a background thread without hiccups.
Mercury
8
star
30

Wacom2Tuio

A small utility that turns Wacom tablet touch input to TUIO (OSX only)
C++
8
star
31

ofxLaserPointer

addon to use a laser pointer as a mouse
C++
7
star
32

ofxChrome

Control a Google Chrome browser in headless mode through OpenFrameworks
C++
7
star
33

ofxiOSGUI

Basic setup for a multi-scene (each with its UI) iOS app/game
Objective-C
7
star
34

ofxImageExportQueue

export any image sequence to disk on N background threads
C++
6
star
35

ofxThreadedImage

ofImage subclass that allows load from disk, load from http, and save to disk in a background thread.
C++
6
star
36

ofxRetinaTrueTypeFont

Easy retina resolution for ofTrueTypeFont
Objective-C
6
star
37

SoundWindow

small class to create different windows (hanning, hamming, triangular, gauss, blackman harris, flat ) to be used for sound windowing This is my first contact with git, so expect lots of nonsense commits and branching
C++
6
star
38

ofxMTJsonParser

Download and parse a JSON file across different threads with very few lines of code.
C++
5
star
39

ofxStateMachine

Customizable Finite State Machine with error/retry flow handling
C++
5
star
40

MacJoystickHIDTest

Mac OS X Joystick HID testing app
C
5
star
41

ofxImageSequenceVideo

Openframeworks addon to playback an image sequence with a similar api to ofVideoPlayer.
C
5
star
42

ofxMacOSScreenSaver

OpenFrameworks Addon to make Screen Savers for OSX
Objective-C++
5
star
43

ofxExternalProcess

OpenFrameworks addon to execute any external process (similar to ofSystem() with more control)
C++
5
star
44

Xcode-OpenFrameworks-Templates

Xcode file templates for OpenFrameworks
5
star
45

ofxInterfaceKeyboard

A configurable Keyboard View for ofxInterface
C++
4
star
46

MoveMyWindow

Simple OS X app to move/resize frontmost window with global keyboard shortcuts
Objective-C++
3
star
47

ofxRetinaImage

simple OF addon that subclasses ofImage to easily handle loading of retina (@2x) images
Objective-C
3
star
48

ofxFailSafeVideoGrabber

Fail-Safe ofVideoGrabber, provides fallback to a user specified movie if videoGrabber not available.
C++
3
star
49

PointGreyCameraInput

The very basics to start a CV project in OF with a firewire camera
C
3
star
50

OpticalFlow

simple OpenCV based OpticalFlow analyzer object
C++
3
star
51

ofxGLError

Easily see OpenGL Error states
C
3
star
52

XcodeColorSchemes

my favourite syntax highlighting for Xcode
3
star
53

MonkeyWatch

Simple WatchDog for OSX
Objective-C
3
star
54

GLSL_DOF

trying to make depth of field with OpenFrameworks
C++
3
star
55

TreeOfLife

TreeOfLife
C++
3
star
56

ofxTagSystem

Create Tag for different Categories and assign to object IDs. Templated to use your custom Tag Categories.
C++
3
star
57

GitRepoTrack

Scan your filesystem for git repos, easily see if it has pending commits
Objective-C
3
star
58

ofxExplosion

Explosion animation
C++
3
star
59

ofxMediaDB

easily reach your various media assets objects from anywhere within your code
C++
3
star
60

ofxTouchHelper

little helper to handle multitouch events
C
3
star
61

ofxVezerRealtime

OF addon to control Vezรฉr through OSC from OpenFrameworks
C++
2
star
62

tetris

a tetris clone to mess around with
C++
2
star
63

ofxMemStats

print mem stats in one single call
C++
2
star
64

ofxImageResizer

Openframeworks addon to help batch resize images across N threads
C++
2
star
65

Due

little OSX countdown app that sits on your menubar
Objective-C
2
star
66

ofxRemoteOfImage

Send an ofImage through the network - unfinished
C++
2
star
67

ofxExplodingString

Simple OF addon to quickly make ofTrueType based strings explode in pieces.
C++
2
star
68

ofxImagePlayer

simple OF addon to load and play back image sequences
Objective-C
2
star
69

ofxSimpleSmoothFilter

C++
2
star
70

ofxFboMipMap

ofFbo subclass that generates/updates its mipmaps automatically
C++
2
star
71

ofxTextureCrop

Simple OF addon to draw an ofTexture within a rect, cropping it appropriately.
C++
2
star
72

SpaceReporter

SpaceReporter is a small utility that sits on your menu bar and tells you how empty (or full) your hard drives are.
Objective-C
2
star
73

ofxTextureMultiOutput

useful for setups where you want to draw in a virtual canvas and you need the output to be laid out in a specific way
C++
2
star
74

SolarSystem

SolarSystem made during the Telenoika OF workshop
C++
2
star
75

ofxImageSequenceExport

OpenFrameworks addon to export frames as an image sequence across N threads.
C++
2
star
76

ofxVsoFont

OF wrapper for VSOFont (a Very Simple OpenGL Font, by Ville Helin). Draws chars using a tiny amount of lines, similar to seven-segment displays
C
2
star
77

ofxGlobalElements

easily reach stuff from everywhere - messy code paradise
C++
2
star
78

Benchmark-map_VS_unordered_map

Quick Benchmark to compare c++ std:map performance to std:unordered_map
C++
1
star
79

ofxAssets

OpenFrameworks classes to handle objects with assets
C++
1
star
80

ofxAutoTexture

Thin ofTexture wrapper that reloads from disk when original asset is modified
C++
1
star
81

ofxThreadSafeLog

threaded log to file
C++
1
star
82

ofxHTTPJsonPost

OpenFrameworks addon to POST json data over HTTP
C++
1
star
83

iPhoneInputExperiments

trying to figure out how to successfully develop analog controls for a car game on an iphone
C++
1
star
84

ofxUserContentUpload

C++
1
star
85

ofxFFmpegUtils

OpenFrameworks addon to easily use FFmpeg to process movie files
C++
1
star
86

FlickrDrop

Crappy Cocoa app to drag-upload pics to flickr, into a defined photoset
Objective-C
1
star
87

MissileCommand

MissileCommand game to be played with laserPointer and Projector
C++
1
star
88

Sardine

abstract swimming sardine
C++
1
star
89

TorPhotoBooth

Objective-C
1
star
90

CocoaWifiCrack

brute force wifi networks using cocoa
Objective-C
1
star
91

TweakBrowser

Quick & dirty Cocoa Web Browser with gamma controls
Objective-C
1
star
92

ofxScreenCorners

OF addon to easily add round corners to you app
C++
1
star
93

keyboardPractice

simple OF app to practice keyboard typing
Objective-C
1
star
94

CustomViewsTest

iOS ui elements subclasses for G
Objective-C
1
star
95

upptime

๐Ÿ“ˆ Uptime monitor and status page for Oriol Ferrer Mesiร , powered by @upptime
Markdown
1
star
96

ofxBezelCompensation

OpenFrameworks addon to easily add bezel compensation to your project
C++
1
star
97

OF_DockerFile

dockerfile to test OpenFrameworks addons
1
star
98

ofxEllipseSolver

given 5 points in 2D space, find an ellipse that goes through all of them
C++
1
star
99

OmmW-Lists

Todo Lists For OmmWriter
1
star
100

ofxSimpleWebServer

Simple web server addon for OpenFrameworks
C++
1
star