rsc3/doc-schelp/HelpSource/Classes/ServerMeterView.schelp

108 lines
3.2 KiB
Text
Raw Normal View History

2022-08-24 13:53:18 +00:00
TITLE:: ServerMeterView
summary:: A GUI widget that displays input/output levels
categories:: GUI>Views
related:: Classes/ScopeView, Classes/FreqScopeView, Classes/ServerMeter
DESCRIPTION::
A link::Classes/ServerMeterView:: is a modular widget for showing the volume levels of inputs/outputs on the server. link::Classes/ServerMeterView:: can be embedded inside of your custom graphical user interfaces just like a button or slider.
note::
If you are looking for a quick input/output levels display without having to build your own GUI from scratch, see link::Classes/ServerMeter:: and link::Classes/Server#-meter::
::
CLASSMETHODS::
METHOD:: height
Get the height in pixels of the standard link::Classes/ServerMeterView:: widget
returns:: an link::Classes/Integer::
METHOD:: getWidth
Get the width in pixels of a link::Classes/ServerMeterView:: widget with the given number of inputs and outputs
ARGUMENT:: numIns
number of inputs used to calculate the width
ARGUMENT:: numOuts
number of outputs used to calculate the width
ARGUMENT:: server
the server
returns:: an link::Classes/Integer::
METHOD:: new
Create a new link::Classes/ServerMeterView:: instance
ARGUMENT:: aserver
The link::Classes/Server:: whose inputs/outputs will be monitored
ARGUMENT:: parent
The parent link::Classes/View:: or link::Classes/Window:: where the new link::Classes/ServerMeterView:: will be embedded.
ARGUMENT:: leftUp
Where to position the new link::Classes/ServerMeterView:: inside the parent. strong::leftUp:: must be a link::Classes/Point::, describing where to place the upper left corner of the new link::Classes/ServerMeterView::.
ARGUMENT:: numIns
The number of inputs to monitor
ARGUMENT:: numOuts
The number of outputs to monitor
returns:: A new link::Classes/ServerMeterView::
INSTANCEMETHODS::
METHOD:: view
get the link::Classes/CompositeView:: used to construct the various elements of the link::Classes/ServerMeterView:: widget
returns:: a link::Classes/CompositeView::
METHOD:: remove
Removes this link::Classes/ServerMeterView:: from its parent view (if any) and then destroys it. Once this method is called you can no longer use this link::Classes/ServerMeterView::.
METHOD:: start
Enable the monitoring of input/outputs
returns:: this link::Classes/ServerMeterView::
METHOD:: stop
Disable the monitoring of input/outputs
returns:: this link::Classes/ServerMeterView::
PRIVATE:: setSynthFunc, startResponders, init
EXAMPLES::
subsection::Simple Usage
code::
// make a window and embed a ServerMeterView inside of it.
w = Window.new("Server Levels");
ServerMeterView.new(s, w, 0@0, 2, 2);
w.front; // show the window
::
subsection::A More Complex Example
code::
// make a GUI to monitor two servers running simultaneously
s = Server.local;
q = Server.internal;
s.boot; q.boot; // wait a moment for the servers to boot
// make a window big enough to hold 2 ServerMeterViews
r = Rect(0, 0, ServerMeterView.getWidth(2, 2) * 2, ServerMeterView.height)
w = Window.new("Local | Internal", r);
// make one ServerMeterView to monitor the input/output of each server
ServerMeterView.new(s, w, Point(0,0), 2, 2);
ServerMeterView.new(q, w, Point(ServerMeterView.getWidth(2,2), 0), 2, 2);
w.front; // show the window
::