Page 1 of 1

Variabeln aus VBS-Macro im ControlPanel darstellen

Posted: Tue 21. Feb 2012, 11:31
by engineer
Hallo,

gibt es eine Möglichkeit, eine interne Macrovariabel auf der Oberfläche des ControlPanels darzustellen
und auch den Wert über eine Eingabe zu beinflussen?

Re: Variabeln aus VBS-Macro im ControlPanel darstellen

Posted: Tue 21. Feb 2012, 15:02
by M.Maidhof
Hallo,

ja das ist moeglich, dazu muessen Sie ihre Variable einem Signal zuordnen. Hier ein Beispiel, wo ein neues Signal in einem VBmacro erzeugt wird. Dieses Signal kann dann auch von einem Panel verwendet werden. Sie koennen das Signal auch vorher schon im Symboleditor als virtuelle Variable erzeugen, damit es im Panel auswaehlbar ist.

Sub CalculatePower()
Dim voltage, current, power

Set voltage = Signals("Voltage")
Set current = Signals("Current")

Set power = Signals("Power")
If power Is Nothing Then
' Signal not found, create and initialize new one
Set power = Signals.Add("Power")
power.DataType = peDataTypeFloat
End If

While True
power.Value = voltage.Value * current.Value
Wait(10) ' Prevent 100% CPU load
Wend

End Sub

Re: Variabeln aus VBS-Macro im ControlPanel darstellen

Posted: Wed 22. Feb 2012, 16:02
by Michael90
Hallo,
vll passend zu dem Thema. Wie kann ich Signalen im Makro ein ValueIndicator im instruments panel zuweisen?

Mir fehlt dazu bisher die Möglichkeit, ein instrumentspanel-objekt zu erzeugen und dazu die Dokumentation zu finden. Oder gibts das gar nicht?

Re: Variabeln aus VBS-Macro im ControlPanel darstellen

Posted: Thu 23. Feb 2012, 09:13
by M.Maidhof
Hallo,

ja, das ist moeglich. Hier ein Beispiel:

Dim doc
Set doc = Documents("MyPanel.ipf")
If Not doc Is Nothing Then
Dim panel, valInd
Set panel = doc.ActiveWindow.Object
Set valInd = panel.ActiveScene.Controls.Add(peControlTypeValueIndicator)
Set valInd.Signal = Signals("MySignal")
End If