diff --git a/config/config.properties b/config/config.properties
index 01be8d8..43bee8a 100755
--- a/config/config.properties
+++ b/config/config.properties
@@ -1,39 +1,40 @@
-#Mon Mar 18 10:44:11 CET 2019
-autoSaveScanData=true
-commandExecutionEvents=false
-createSessionFiles=false
-dataLayout=sf
-dataPath={data}/{year}/{month}/{day}/{date}_{time}_{name}
-dataProvider=default
-dataScanFlushRecords=false
-dataScanPreserveTypes=false
-dataScanReleaseRecords=false
-dataScanStrategy=default
-dataServerPort=-1
-depthDimension=0
-devicePoolFile={config}/devices.properties
-deviceUpdateStrategyFile={config}/update.properties
-hideServerMessages=false
+#Thu Nov 07 14:59:30 CET 2019
hostName=
-instanceName=OP
-logDaysToLive=30
-logLevel=Fine
-logLevelConsole=Off
-logPath={logs}/{date}_{time}
-notificationLevel=null
-saveCommandStatistics=false
-scanDataRelease=false
-scanStreamerPort=-1
-scanStreamingPort=-1
-serverEnabled=true
-serverPort=8090
-simulation=false
-tasksFile={config}/tasks.properties
-terminalEnabled=false
-terminalPort=3579
-userAuthenticator=
userManagement=false
+instanceName=OP
+autoSaveScanData=true
+simulation=false
+dataServerPort=-1
+hideServerMessages=false
+serverPort=8090
versionTrackingEnabled=true
+dataPath={data}/{year}/{month}/{day}/{date}_{time}_{name}
+serverEnabled=true
+commandExecutionEvents=false
+logDaysToLive=30
+dataScanReleaseRecords=false
+depthDimension=0
+dataScanPreserveTypes=false
+logLevel=Fine
+dataScanFlushRecords=false
+logPath={logs}/{date}_{time}
+dataLayout=sf
+deviceUpdateStrategyFile={config}/update.properties
+terminalEnabled=false
+notificationLevel=null
+userAuthenticator=
+logLevelConsole=Off
+terminalPort=3579
+tasksFile={config}/tasks.properties
+dataScanStrategy=default
+scanStreamerPort=-1
+parallelInitialization=false
+scanDataRelease=false
+createSessionFiles=false
+scanStreamingPort=-1
versionTrackingLogin={context}/svcusr-hlapp_robot
+devicePoolFile={config}/devices.properties
versionTrackingManual=true
versionTrackingRemote=git@git.psi.ch\:pshell_config/sf-op.git
+dataProvider=default
+saveCommandStatistics=false
diff --git a/config/settings.properties b/config/settings.properties
index df7ac7e..1ba8d70 100644
--- a/config/settings.properties
+++ b/config/settings.properties
@@ -1,22 +1,22 @@
-#Mon Jul 01 14:54:49 CEST 2019
-S10CB04-DBLM240GainWsX1=0.6
-S10CB04-DBLM240_saturation=39.4
-S10DI01-DBLM045GainWsX1=0.8800000000000003
-S10DI01-DBLM045GainWsX2=0.8800000000000003
-S10DI01-DBLM045GainWsY1=0.7600000000000002
-S10DI01-DBLM045GainWsY2=0.8800000000000003
-S10DI01-DBLM045_saturation=245.5
-S10DI02-DBLM025GainWsY2=0.9
+#Tue Feb 04 11:37:22 CET 2020
S20SY03-DBLM110GainWsX1=0.8800000000000003
S20SY03-DBLM110GainWsY1=0.9200000000000004
-SARCL02-DBLM135GainWsX1=0.9
-SARCL02-DBLM135GainWsX2=0.8600000000000003
-SARCL02-DBLM135GainWsY1=0.9556983528903381
-SARCL02-DBLM135_saturation=314.9
-SINDI02-DBLM025GainWsX1=0.6
-SINDI02-DBLM025GainWsX2=0.6
-SINDI02-DBLM025GainWsY1=0.6200000000000001
-SINDI02-DBLM025GainWsY2=0.7593208544828762
-SINDI02-DBLM025GainWsx=0.5397269806333481
SINDI02-DBLM025_saturation=1310.3
+S10CB04-DBLM240GainWsX1=0.6
+SARCL02-DBLM135_saturation=314.9
+SINDI02-DBLM025GainWsX2=0.6
+S10DI01-DBLM045_saturation=245.5
+S10DI02-DBLM025GainWsY2=0.9
+SINDI02-DBLM025GainWsX1=0.6
+SINDI02-DBLM025GainWsY2=0.7593208544828762
+SINDI02-DBLM025GainWsY1=0.6200000000000001
+S10DI01-DBLM045GainWsX2=0.8800000000000003
+S10CB04-DBLM240_saturation=39.4
+S10DI01-DBLM045GainWsY1=0.7600000000000002
+SINDI02-DBLM025GainWsx=0.5397269806333481
+S10DI01-DBLM045GainWsX1=0.8800000000000003
+S10DI01-DBLM045GainWsY2=0.8800000000000003
SINDI02-DBLM085GainWsX1=0.6800000000000002
+SARCL02-DBLM135GainWsY1=0.9556983528903381
+SARCL02-DBLM135GainWsX2=0.8600000000000003
+SARCL02-DBLM135GainWsX1=1.1
diff --git a/config/setup.properties b/config/setup.properties
index 5760c44..0f12736 100755
--- a/config/setup.properties
+++ b/config/setup.properties
@@ -1,10 +1,11 @@
-#Tue Dec 18 10:08:26 CET 2018
+#Fri Sep 06 11:37:43 CEST 2019
configFile={config}/config.properties
configFileDevices={config}/devices.properties
configFilePlugins={config}/plugins.properties
configFileSettings={config}/settings.properties
configFileTasks={config}/tasks.properties
configFileUpdateStrategy={config}/update.properties
+configFileVariables={config}/variables.properties
configPath={home}/config
contextPath={outp}/context
dataPath={outp}/data
diff --git a/config/variables.properties b/config/variables.properties
new file mode 100644
index 0000000..53d029b
--- /dev/null
+++ b/config/variables.properties
@@ -0,0 +1,2 @@
+#Thu Feb 06 18:39:13 CET 2020
+FileSequentialNumber=1250
diff --git a/devices/CurrentCamera.properties b/devices/CurrentCamera.properties
index 85bdaf5..de37aa9 100644
--- a/devices/CurrentCamera.properties
+++ b/devices/CurrentCamera.properties
@@ -1,37 +1,41 @@
-#Wed Aug 07 14:14:42 CEST 2019
-\u0000=
-\u0000\u0000\u0000\u0000=
-\u0000\u0000\u0000\u0000\u0000\u0000=
-\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000=
-\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000=
+#Fri Feb 07 11:39:15 CET 2020
+\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000=
\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000=
-colormap=Flame
-colormapAutomatic=false
+\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000=
+\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000=
+\u0000\u0000\u0000\u0000\u0000\u0000=
+\u0000\u0000\u0000\u0000=
+\u0000=
+\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000\u0000=
+spatialCalOffsetY=-50.048875855327466
+spatialCalOffsetX=-50.03909304143862
colormapLogarithmic=false
-colormapMax=65535.0
-colormapMin=39864.0
-flipHorizontally=false
-flipVertically=false
-grayscale=false
-imageHeight=494
-imageWidth=659
-invert=false
-regionStartX=0
-regionStartY=0
-rescaleFactor=1.0
-rescaleOffset=0.0
-roiHeight=-1
-roiWidth=-1
-roiX=0
-roiY=0
-rotation=0.0
-rotationCrop=false
scale=1.0
-serverURL=null
-spatialCalOffsetX=-50.01953888237593
-spatialCalOffsetY=-50.032030749519535
+grayscale=false
spatialCalScaleX=-1.0
spatialCalScaleY=-1.0
+serverURL=null
+colormapMax=6283.0
+rescaleOffset=0.0
+roiWidth=-1
+colormap=Flame
+imageWidth=1744
+invert=false
+spat=
+colormapMin=46.0
+rotationCrop=false
+rotation=0.0
+rescaleFactor=1.0
+imageHeight=1680
spatialCalUnits=null
+flipVertically=false
+r=
+roiHeight=-1
t=
+flipHorizontally=false
+colormapAutomatic=true
+roiY=0
+roiX=0
transpose=false
+regionStartX=433
+regionStartY=241
diff --git a/devices/Image Averager.properties b/devices/Image Averager.properties
index 2fb4981..c1aea4d 100644
--- a/devices/Image Averager.properties
+++ b/devices/Image Averager.properties
@@ -1,29 +1,29 @@
-#Mon Jul 29 16:11:27 CEST 2019
-colormap=Flame
-colormapAutomatic=true
+#Sat Jan 25 10:00:39 CET 2020
+spatialCalOffsetY=-283.472459616368
+spatialCalOffsetX=-508.635792340687
colormapLogarithmic=false
-colormapMax=1023.0
-colormapMin=0.0
-flipHorizontally=false
-flipVertically=false
+scale=1.0
grayscale=false
-imageHeight=494
+spatialCalScaleX=-11.968979779411764
+spatialCalScaleY=-10.638298123826168
+colormapMax=45095.0
+rescaleOffset=0.0
+roiWidth=-1
+colormap=Flame
imageWidth=659
invert=false
+colormapMin=74.0
+rotationCrop=false
+rotation=0.0
+rescaleFactor=1.0
+imageHeight=494
+spatialCalUnits=null
+flipVertically=false
+roiHeight=-1
+flipHorizontally=false
+colormapAutomatic=true
+roiY=0
+roiX=0
+transpose=false
regionStartX=0
regionStartY=0
-rescaleFactor=1.0
-rescaleOffset=0.0
-roiHeight=-1
-roiWidth=-1
-roiX=0
-roiY=0
-rotation=0.0
-rotationCrop=false
-scale=1.0
-spatialCalOffsetX=-456.693006929345
-spatialCalOffsetY=-219.4442130289473
-spatialCalScaleX=-14.937285913160144
-spatialCalScaleY=-11.834319139832656
-spatialCalUnits=null
-transpose=false
diff --git a/devices/SINEG01-DSCR190.properties b/devices/SINEG01-DSCR190.properties
new file mode 100644
index 0000000..a3c5bf0
--- /dev/null
+++ b/devices/SINEG01-DSCR190.properties
@@ -0,0 +1,29 @@
+#Fri Aug 30 09:40:43 CEST 2019
+colormap=Grayscale
+colormapAutomatic=false
+colormapLogarithmic=false
+colormapMax=NaN
+colormapMin=NaN
+flipHorizontally=false
+flipVertically=true
+grayscale=false
+imageHeight=1200
+imageWidth=1246
+invert=false
+regionStartX=304
+regionStartY=8
+rescaleFactor=1.0
+rescaleOffset=0.0
+roiHeight=-1
+roiWidth=-1
+roiX=0
+roiY=0
+rotation=0.0
+rotationCrop=false
+scale=1.0
+spatialCalOffsetX=-606.0
+spatialCalOffsetY=-602.0
+spatialCalScaleX=-26.714158504007123
+spatialCalScaleY=-27.100271002710027
+spatialCalUnits=mm
+transpose=false
diff --git a/devices/WireScanner motor.properties b/devices/WireScanner motor.properties
index f84868c..5fd46e9 100644
--- a/devices/WireScanner motor.properties
+++ b/devices/WireScanner motor.properties
@@ -1,17 +1,18 @@
-#Mon Jul 29 18:07:39 CEST 2019
-defaultSpeed=2000.0
-estbilizationDelay=0
-hasEnable=false
-homingType=None
-maxSpeed=2000.0
-maxValue=66050.0
-minSpeed=50.0
-minValue=-50603.0
+#Tue Feb 04 11:46:29 CET 2020
offset=0.0
+maxValue=51500.0
precision=1
-resolution=0.1
rotation=false
scale=1.0
-sign_bit=0
+estbilizationDelay=0
+maxSpeed=2000.0
+resolution=0.1
+homingType=None
startRetries=1
+minValue=-56300.0
unit=um
+defaultSpeed=2000.0
+hasEnable=false
+sign_bit=0
+monitorByPosition=false
+minSpeed=50.0
diff --git a/devices/cam_server.properties b/devices/cam_server.properties
index 4196ffb..d82f7e5 100644
--- a/devices/cam_server.properties
+++ b/devices/cam_server.properties
@@ -1,25 +1,25 @@
-#Thu Jun 13 16:35:07 CEST 2019
-colormap=Flame
-colormapAutomatic=true
-colormapLogarithmic=false
-colormapMax=NaN
-colormapMin=NaN
-flipHorizontally=false
-flipVertically=false
-grayscale=false
-invert=false
-rescaleFactor=1.0
-rescaleOffset=0.0
-roiHeight=-1
-roiWidth=-1
-roiX=0
-roiY=0
-rotation=0.0
-rotationCrop=false
-scale=1.0
-spatialCalOffsetX=-861.4939970777481
+#Thu Feb 06 15:36:29 CET 2020
spatialCalOffsetY=-820.4883730911062
+spatialCalOffsetX=-861.4939970777481
+colormapLogarithmic=false
+scale=1.0
+grayscale=false
spatialCalScaleX=-18.90359092620482
spatialCalScaleY=-19.37984500632817
+colormapMax=NaN
+rescaleOffset=0.0
+roiWidth=-1
+colormap=Flame
+invert=false
+colormapMin=NaN
+rotation=0.0
+rotationCrop=false
+rescaleFactor=1.0
spatialCalUnits=mm
+flipVertically=false
+roiHeight=-1
+flipHorizontally=false
+colormapAutomatic=true
+roiY=0
+roiX=0
transpose=false
diff --git a/devices/dispatcher.properties b/devices/dispatcher.properties
index d09fa10..4048ec2 100644
--- a/devices/dispatcher.properties
+++ b/devices/dispatcher.properties
@@ -1,14 +1,15 @@
-#Thu Apr 05 14:20:51 CEST 2018
-alignmentRetries=20
-disableCompression=false
-dropIncomplete=false
-keepListeningOnStop=false
-mappingIncomplete=fill_null
-parallelHandlerProcessing=true
-sendAwaitFirstMessage=false
-sendBuildChannelConfig=at_startup
-sendIncompleteMessages=true
+#Tue Nov 19 12:01:37 CET 2019
sendStrategy=complete_all
-sendSyncTimeout=0
+dropIncomplete=false
+disableCompression=false
+keepListeningOnStop=false
+parallelHandlerProcessing=true
+sendBuildChannelConfig=at_startup
+sendAwaitFirstMessage=false
socketType=DEFAULT
validationInconsistency=keep_as_is
+byteBufferAllocator=false
+alignmentRetries=20
+mappingIncomplete=fill_null
+sendIncompleteMessages=true
+sendSyncTimeout=0
diff --git a/devices/kick.properties b/devices/kick.properties
new file mode 100644
index 0000000..4ff8701
--- /dev/null
+++ b/devices/kick.properties
@@ -0,0 +1,10 @@
+#Thu Sep 19 19:14:35 CEST 2019
+minValue=-10.0
+unit=A
+offset=0.0
+maxValue=10.0
+rotation=false
+precision=3
+sign_bit=0
+scale=1.0
+resolution=0.1
diff --git a/devices/kick1.properties b/devices/kick1.properties
new file mode 100644
index 0000000..61f5264
--- /dev/null
+++ b/devices/kick1.properties
@@ -0,0 +1,10 @@
+#Tue Sep 24 16:19:09 CEST 2019
+minValue=-10.0
+unit=A
+offset=0.0
+maxValue=10.0
+rotation=false
+precision=3
+sign_bit=0
+scale=1.0
+resolution=NaN
diff --git a/devices/kick2.properties b/devices/kick2.properties
new file mode 100644
index 0000000..61f5264
--- /dev/null
+++ b/devices/kick2.properties
@@ -0,0 +1,10 @@
+#Tue Sep 24 16:19:09 CEST 2019
+minValue=-10.0
+unit=A
+offset=0.0
+maxValue=10.0
+rotation=false
+precision=3
+sign_bit=0
+scale=1.0
+resolution=NaN
diff --git a/devices/kick3.properties b/devices/kick3.properties
new file mode 100644
index 0000000..812ef22
--- /dev/null
+++ b/devices/kick3.properties
@@ -0,0 +1,10 @@
+#Tue Oct 08 09:19:39 CEST 2019
+minValue=-10.0
+unit=A
+offset=0.0
+maxValue=10.0
+rotation=false
+precision=3
+sign_bit=0
+scale=1.0
+resolution=NaN
diff --git a/devices/m1.properties b/devices/m1.properties
index 2d196a2..6cf88ae 100755
--- a/devices/m1.properties
+++ b/devices/m1.properties
@@ -1,14 +1,16 @@
-#Wed Mar 28 14:33:20 CEST 2018
-defaultSpeed=1.0
-estbilizationDelay=0
-maxSpeed=10.0
-maxValue=10.0
-minSpeed=0.1
-minValue=-10.0
+#Mon Sep 23 17:29:11 CEST 2019
offset=0.0
+maxValue=10.0
precision=2
-resolution=NaN
rotation=false
scale=1.0
+estbilizationDelay=0
+maxSpeed=10.0
+resolution=NaN
startRetries=1
+minValue=-10.0
unit=mm
+defaultSpeed=1.0
+sign_bit=0
+monitorByPosition=false
+minSpeed=0.1
diff --git a/devices/m2.properties b/devices/m2.properties
index 2d196a2..6cf88ae 100755
--- a/devices/m2.properties
+++ b/devices/m2.properties
@@ -1,14 +1,16 @@
-#Wed Mar 28 14:33:20 CEST 2018
-defaultSpeed=1.0
-estbilizationDelay=0
-maxSpeed=10.0
-maxValue=10.0
-minSpeed=0.1
-minValue=-10.0
+#Mon Sep 23 17:29:11 CEST 2019
offset=0.0
+maxValue=10.0
precision=2
-resolution=NaN
rotation=false
scale=1.0
+estbilizationDelay=0
+maxSpeed=10.0
+resolution=NaN
startRetries=1
+minValue=-10.0
unit=mm
+defaultSpeed=1.0
+sign_bit=0
+monitorByPosition=false
+minSpeed=0.1
diff --git a/devices/p1.properties b/devices/p1.properties
index 7b725f5..9092287 100755
--- a/devices/p1.properties
+++ b/devices/p1.properties
@@ -1,9 +1,10 @@
-#Tue Jul 11 15:24:17 CEST 2017
-maxValue=1000.0
+#Mon Sep 23 17:29:11 CEST 2019
minValue=0.0
-offset=0.0
-precision=-1
-resolution=NaN
-rotation=false
-scale=1.0
unit=mm
+offset=0.0
+maxValue=1000.0
+precision=-1
+rotation=false
+sign_bit=0
+scale=1.0
+resolution=NaN
diff --git a/devices/quad.properties b/devices/quad.properties
new file mode 100644
index 0000000..439f98b
--- /dev/null
+++ b/devices/quad.properties
@@ -0,0 +1,10 @@
+#Tue Sep 24 16:19:09 CEST 2019
+minValue=0.0
+unit=1/m
+offset=0.0
+maxValue=0.0
+rotation=false
+precision=3
+sign_bit=0
+scale=1.0
+resolution=NaN
diff --git a/devices/src1.properties b/devices/src1.properties
index 04ea689..1e4168e 100755
--- a/devices/src1.properties
+++ b/devices/src1.properties
@@ -1,24 +1,25 @@
-#Tue Aug 30 17:36:05 CEST 2016
-colormap=Temperature
-colormapAutomatic=true
-colormapMax=255.0
-colormapMin=0.0
-flipHorizontally=false
-flipVertically=false
-grayscale=false
-invert=false
-rescaleFactor=1.0
-rescaleOffset=0.0
-roiHeight=-1
-roiWidth=-1
-roiX=0
-roiY=0
-rotation=0.0
-rotationCrop=false
-scale=1.0
-spatialCalOffsetX=NaN
+#Mon Sep 23 17:29:11 CEST 2019
spatialCalOffsetY=NaN
+spatialCalOffsetX=NaN
+colormapLogarithmic=false
+scale=1.0
+grayscale=false
spatialCalScaleX=NaN
spatialCalScaleY=NaN
+colormapMax=255.0
+rescaleOffset=0.0
+roiWidth=-1
+colormap=Temperature
+invert=false
+colormapMin=0.0
+rotation=0.0
+rotationCrop=false
+rescaleFactor=1.0
spatialCalUnits=mm
+flipVertically=false
+roiHeight=-1
+flipHorizontally=false
+colormapAutomatic=true
+roiY=0
+roiX=0
transpose=false
diff --git a/devices/src2.properties b/devices/src2.properties
index bdd5ae4..efe74f5 100755
--- a/devices/src2.properties
+++ b/devices/src2.properties
@@ -1,24 +1,25 @@
-#Tue Aug 30 17:36:05 CEST 2016
-colormap=Grayscale
-colormapAutomatic=true
-colormapMax=255.0
-colormapMin=0.0
-flipHorizontally=false
-flipVertically=false
-grayscale=false
-invert=false
-rescaleFactor=1.0
-rescaleOffset=0.0
-roiHeight=-1
-roiWidth=-1
-roiX=0
-roiY=0
-rotation=0.0
-rotationCrop=false
-scale=1.0
-spatialCalOffsetX=NaN
+#Mon Sep 23 17:29:11 CEST 2019
spatialCalOffsetY=NaN
+spatialCalOffsetX=NaN
+colormapLogarithmic=false
+scale=1.0
+grayscale=false
spatialCalScaleX=NaN
spatialCalScaleY=NaN
+colormapMax=255.0
+rescaleOffset=0.0
+roiWidth=-1
+colormap=Grayscale
+invert=false
+colormapMin=0.0
+rotation=0.0
+rotationCrop=false
+rescaleFactor=1.0
spatialCalUnits=mm
+flipVertically=false
+roiHeight=-1
+flipHorizontally=false
+colormapAutomatic=true
+roiY=0
+roiX=0
transpose=false
diff --git a/plugins/ScreenPanel5.form b/plugins/ScreenPanel5.form
new file mode 100644
index 0000000..d6332ab
--- /dev/null
+++ b/plugins/ScreenPanel5.form
@@ -0,0 +1,1299 @@
+
+
+
diff --git a/plugins/ScreenPanel5.java b/plugins/ScreenPanel5.java
new file mode 100644
index 0000000..3b3919a
--- /dev/null
+++ b/plugins/ScreenPanel5.java
@@ -0,0 +1,4447 @@
+/*
+ * Copyright (c) 2014 Paul Scherrer Institute. All rights reserved.
+ */
+
+import ch.psi.pshell.bs.CameraServer;
+import ch.psi.pshell.core.Context;
+import java.io.IOException;
+import java.nio.file.Paths;
+import javax.swing.DefaultComboBoxModel;
+import ch.psi.pshell.ui.Panel;
+import ch.psi.pshell.imaging.ImageListener;
+import ch.psi.utils.State;
+import ch.psi.utils.Chrono;
+import ch.psi.utils.swing.SwingUtils;
+import ch.psi.utils.swing.TextEditor;
+import ch.psi.pshell.bs.PipelineServer;
+import ch.psi.pshell.bs.StreamValue;
+import ch.psi.pshell.core.JsonSerializer;
+import ch.psi.pshell.data.DataManager;
+import ch.psi.pshell.device.Device;
+import ch.psi.pshell.device.Readable.ReadableArray;
+import ch.psi.pshell.device.Readable.ReadableNumber;
+import ch.psi.pshell.device.ReadableRegister.ReadableRegisterArray;
+import ch.psi.pshell.device.ReadableRegister.ReadableRegisterNumber;
+import ch.psi.pshell.epics.ChannelInteger;
+import ch.psi.pshell.epics.DiscretePositioner;
+import ch.psi.pshell.epics.Epics;
+import ch.psi.pshell.imaging.Colormap;
+import ch.psi.pshell.imaging.ColormapSource;
+import ch.psi.pshell.imaging.ColormapSource.ColormapSourceConfig;
+import ch.psi.pshell.ui.App;
+import ch.psi.pshell.imaging.Data;
+import ch.psi.pshell.imaging.DimensionDouble;
+import ch.psi.pshell.imaging.Histogram;
+import ch.psi.pshell.imaging.ImageBuffer;
+import ch.psi.pshell.imaging.Overlay;
+import ch.psi.pshell.imaging.Overlays;
+import ch.psi.pshell.imaging.Overlays.Text;
+import ch.psi.pshell.imaging.Pen;
+import ch.psi.pshell.imaging.PointDouble;
+import ch.psi.pshell.imaging.Renderer;
+import ch.psi.pshell.imaging.RendererListener;
+import ch.psi.pshell.imaging.RendererMode;
+import ch.psi.pshell.imaging.Source;
+import ch.psi.pshell.scripting.InterpreterResult;
+import ch.psi.pshell.scripting.ScriptManager;
+import ch.psi.pshell.swing.DeviceValueChart;
+import ch.psi.pshell.swing.ValueSelection;
+import ch.psi.pshell.swing.ValueSelection.ValueSelectionListener;
+import ch.psi.pshell.ui.Console;
+import ch.psi.utils.Arr;
+import ch.psi.utils.ArrayProperties;
+import ch.psi.utils.Config;
+import ch.psi.utils.Convert;
+import ch.psi.utils.Str;
+import ch.psi.utils.swing.Editor.EditorDialog;
+import ch.psi.utils.swing.MainFrame;
+import ch.psi.utils.swing.StandardDialog;
+import ch.psi.utils.swing.StandardDialog.StandardDialogListener;
+import ch.psi.utils.swing.SwingUtils.OptionResult;
+import ch.psi.utils.swing.SwingUtils.OptionType;
+import java.awt.Color;
+import java.awt.Component;
+import java.awt.Dimension;
+import java.awt.Font;
+import java.awt.GridBagConstraints;
+import java.awt.GridBagLayout;
+import java.awt.Point;
+import java.awt.Rectangle;
+import java.awt.Toolkit;
+import java.awt.datatransfer.Clipboard;
+import java.awt.datatransfer.StringSelection;
+import java.awt.datatransfer.Transferable;
+import java.awt.event.ActionEvent;
+import java.awt.event.MouseAdapter;
+import java.awt.event.MouseEvent;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.awt.image.BufferedImage;
+import java.io.File;
+import java.io.FileInputStream;
+import java.lang.reflect.Array;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Properties;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+import javax.swing.ImageIcon;
+import javax.swing.JButton;
+import javax.swing.JCheckBox;
+import javax.swing.JCheckBoxMenuItem;
+import javax.swing.JComboBox;
+import javax.swing.JComponent;
+import javax.swing.JDialog;
+import javax.swing.JLabel;
+import javax.swing.JMenu;
+import javax.swing.JMenuItem;
+import javax.swing.JPanel;
+import javax.swing.JScrollPane;
+import javax.swing.JSpinner;
+import javax.swing.JTable;
+import javax.swing.JTextField;
+import javax.swing.ListSelectionModel;
+import javax.swing.SwingUtilities;
+import javax.swing.event.PopupMenuEvent;
+import javax.swing.event.PopupMenuListener;
+import javax.swing.table.DefaultTableModel;
+import org.apache.commons.math3.analysis.function.Gaussian;
+import org.apache.commons.math3.fitting.GaussianCurveFitter;
+import org.apache.commons.math3.fitting.PolynomialCurveFitter;
+import org.apache.commons.math3.fitting.WeightedObservedPoint;
+import org.apache.commons.math3.stat.descriptive.DescriptiveStatistics;
+
+/**
+ *
+ */
+public class ScreenPanel5 extends Panel {
+
+ public static final String LASER_TYPE = "Laser";
+ public static final String ELECTRONS_TYPE = "Electrons";
+ public static final String PHOTONICS_TYPE = "Photonics";
+
+ final String CAMERA_DEVICE_NAME = "CurrentCamera";
+ boolean useServerStats = true;
+ String userOverlaysConfigFile;
+ ColormapSource camera;
+ PipelineServer server;
+ String cameraName;
+ int polling = 1000;
+ Overlay marker = null;
+ JDialog histogramDialog;
+ DiscretePositioner screen;
+ DiscretePositioner filter;
+ boolean showFit;
+ boolean showProfile;
+ Overlay[] userOv;
+ Overlay[] fitOv;
+ Overlay[] profileOv;
+ Overlay errorOverlay;
+ boolean requestCameraListUpdate;
+ boolean goodRegion;
+ boolean slicing;
+ String serverUrl;
+ String camServerUrl;
+ String instanceName;
+ Overlay titleOv = null;
+ int integration = 0;
+ boolean persistCameraState;
+
+ public class CameraState extends Config {
+
+ public boolean valid;
+ public boolean showSidePanel;
+ //public boolean showMarker; Saved in the stream instance config
+ public boolean showProfile;
+ public boolean showFit;
+ public boolean showReticle;
+ public boolean showScale;
+ public boolean showTitle;
+ public double zoom;
+ public RendererMode mode;
+ public boolean colormapAutomatic;
+ public double colormapMin;
+ public double colormapMax;
+ public Colormap colormap;
+ public boolean colormapLogarithmic;
+
+ String getFile() {
+ if (camera == null) {
+ return null;
+ }
+ return getContext().getSetup().expandPath("{context}/screen_panel/" + cameraName + ".properties");
+ }
+ }
+
+ void loadCameraState() {
+ if (persistCameraState) {
+ try {
+ CameraState state = new CameraState();
+ state.load(state.getFile());
+ if (state.valid) {
+ buttonSidePanel.setSelected(state.showSidePanel);
+ buttonSidePanelActionPerformed(null);
+ buttonProfile.setSelected(state.showProfile);
+ buttonProfileActionPerformed(null);
+ buttonFit.setSelected(state.showFit);
+ buttonFitActionPerformed(null);
+ buttonReticle.setSelected(state.showReticle);
+ buttonReticleActionPerformed(null);
+ buttonScale.setSelected(state.showScale);
+ buttonScaleActionPerformed(null);
+ buttonTitle.setSelected(state.showTitle);
+ buttonTitleActionPerformed(null);
+ renderer.setMode(state.mode);
+ renderer.setZoom(state.zoom);
+ if (camera instanceof ColormapSource) {
+ camera.getConfig().colormap = state.colormap;
+ camera.getConfig().colormapAutomatic = state.colormapAutomatic;
+ camera.getConfig().colormapLogarithmic = state.colormapLogarithmic;
+ camera.getConfig().colormapMax = state.colormapMax;
+ camera.getConfig().colormapMin = state.colormapMin;
+ updateColormap();
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ }
+
+ void saveCameraState() {
+ if (persistCameraState) {
+ try {
+ CameraState state = new CameraState();
+ state.valid = true;
+ if (camera instanceof ColormapSource) {
+ state.colormap = camera.getConfig().colormap;
+ state.colormapAutomatic = camera.getConfig().colormapAutomatic;
+ state.colormapLogarithmic = camera.getConfig().colormapLogarithmic;
+ state.colormapMax = camera.getConfig().colormapMax;
+ state.colormapMin = camera.getConfig().colormapMin;
+ }
+ state.mode = renderer.getMode();
+ state.zoom = renderer.getZoom();
+
+ state.showSidePanel = buttonSidePanel.isSelected();
+ state.showProfile = buttonProfile.isSelected();
+ state.showFit = buttonFit.isSelected();
+ state.showReticle = buttonReticle.isSelected();
+ state.showScale = buttonScale.isSelected();
+ state.showTitle = buttonTitle.isSelected();
+
+ state.save(state.getFile());
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ }
+
+ String pipelineSuffix = "_sp";
+
+ Double getServerDouble(String name) {
+ return (Double) Convert.toDouble(server.getValue(name));
+ }
+
+ double[] getServerDoubleArray(String name) {
+ return (double[]) Convert.toDouble(server.getValue(name));
+ }
+
+ class ImageData {
+
+ ImageData() {
+ if (server != null) {
+ cache = server.getStream().take();
+ String prefix = goodRegion ? "gr_" : "";
+ x_fit_mean = getDouble(prefix + "x_fit_mean");
+ y_fit_mean = getDouble(prefix + "y_fit_mean");
+ x_fit_standard_deviation = getDouble(prefix + "x_fit_standard_deviation");
+ y_fit_standard_deviation = getDouble(prefix + "y_fit_standard_deviation");
+ x_fit_gauss_function = getDoubleArray(prefix + "x_fit_gauss_function");
+ y_fit_gauss_function = getDoubleArray(prefix + "y_fit_gauss_function");
+ x_profile = getDoubleArray("x_profile");
+ y_profile = getDoubleArray("y_profile");
+ x_center_of_mass = getDouble("x_center_of_mass");
+ y_center_of_mass = getDouble("y_center_of_mass");
+ x_rms = getDouble("x_rms");
+ y_rms = getDouble("y_rms");
+ if (goodRegion) {
+ double[] gX2 = new double[x_profile.length];
+ Arrays.fill(gX2, Double.NaN);
+ try {
+ double[] axis = getDoubleArray("x_axis");
+ gr_x_axis = getDoubleArray("gr_x_axis");
+ double x = gr_x_axis[0];
+ gr_size_x = x_fit_gauss_function.length;
+ //If gr axis values are not identical, calculate the index...
+ gr_pos_x = (int) ((renderer.getCalibration() != null) ? renderer.getCalibration().convertToImageX(x) : x);
+ //But prefer checking the value to avoid raounding errors
+ for (int i=0;i imageBuffer = new ArrayList();
+ Frame currentFrame;
+ int imageBufferLenght = 1;
+ Text imagePauseOverlay;
+ final Console console;
+
+ public ScreenPanel5() {
+ try {
+ initComponents();
+ spinnerThreshold.setVisible(false);
+ btFixColormapRange.setVisible(false);
+ setGoodRegionOptionsVisible(false);
+ setSlicingOptionsVisible(false);
+ setRotationOptionsVisible(false);
+ JComponent editor = spinnerSlOrientation.getEditor();
+ if (editor instanceof JSpinner.DefaultEditor) {
+ ((JSpinner.DefaultEditor) editor).getTextField().setHorizontalAlignment(JTextField.RIGHT);
+ }
+ renderer.setPersistenceFile(Paths.get(getContext().getSetup().getContextPath(), "Renderer_Cameras.bin"));
+ //setPersistedComponents(new Component[]{buttonServer, buttonDirect});
+ setPersistedComponents(new Component[]{buttonTitle});
+ comboCameras.setEnabled(false);
+ comboType.setEnabled(false);
+
+ SwingUtils.setEnumCombo(comboColormap, Colormap.class);
+ if (App.hasArgument("poll")) {
+ try {
+ polling = Integer.valueOf(App.getArgumentValue("poll"));
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ if (App.hasArgument("zoom")) {
+ try {
+ renderer.setDefaultZoom(Double.valueOf(App.getArgumentValue("zoom")));
+ renderer.resetZoom();
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ if (App.hasArgument("buf")) {
+ try {
+ imageBufferLenght = Integer.valueOf(App.getArgumentValue("buf"));
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+
+ if (App.hasArgument("usr_ov")) {
+ try {
+ userOverlaysConfigFile = App.getArgumentValue("usr_ov");
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+
+ if (App.hasArgument("srv_url")) {
+ serverUrl = App.getArgumentValue("srv_url");
+ }
+
+ if (App.hasArgument("cam_srv_url")) {
+ camServerUrl = App.getArgumentValue("cam_srv_url");
+ }
+
+ if (App.hasArgument("calc")) {
+ useServerStats = false;
+ }
+
+ if (App.hasArgument("persist")) {
+ persistCameraState = true;
+ }
+
+ if (App.hasArgument("suffix")) {
+ pipelineSuffix = App.getArgumentValue("suffix");
+ }
+ if (App.hasArgument("integration")) {
+ try {
+ setIntegration(Integer.valueOf(App.getArgumentValue("integration")));
+ if (integration != 0) {
+ buttonFit.setSelected(false);
+ buttonProfile.setSelected(false);
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+
+ renderer.setProfileNormalized(true);
+ renderer.setShowProfileLimits(false);
+
+ JMenuItem menuCalibrate = new JMenuItem("Calibrate...");
+ menuCalibrate.addActionListener((ActionEvent e) -> {
+ try {
+ calibrate();
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ });
+
+ JMenuItem menuRendererConfig = new JMenuItem("Renderer Parameters");
+ menuRendererConfig.addActionListener((ActionEvent e) -> {
+ try {
+ if (camera != null) {
+ this.showDeviceConfigDialog(camera, false);
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ });
+
+ JMenuItem menuCameraConfig = new JMenuItem("Camera Configurarion");
+ menuCameraConfig.addActionListener((ActionEvent e) -> {
+ try {
+ if (camera != null) {
+ String cameraConfigJson = null;
+ if (usingServer) {
+ String cameraServerUrl = (camServerUrl == null) ? server.getUrl().substring(0, server.getUrl().length() - 1) + "8" : camServerUrl;
+ try (CameraServer srv = new CameraServer("CamServer", cameraServerUrl)) {
+ srv.initialize();
+ //TODO: replace into encodeMultiline
+ cameraConfigJson = JsonSerializer.encode(srv.getConfig(cameraName), true);
+ }
+
+ } else {
+ String configFolder = (String) getContext().getClassByName("SfCamera").getMethod("getConfigFolder", new Class[]{}).invoke(null);
+ Path configFile = Paths.get(configFolder, cameraName + ".json");
+ cameraConfigJson = configFile.toFile().exists() ? new String(Files.readAllBytes(configFile)) : null;
+ }
+ TextEditor configEditor = new TextEditor();
+ configEditor.setText(cameraConfigJson);
+ configEditor.setReadOnly(true);
+ configEditor.setTitle(cameraName);
+ EditorDialog dlg = configEditor.getDialog(getTopLevel(), false);
+ dlg.setSize(480, 640);
+ dlg.setVisible(true);
+ SwingUtils.centerComponent(getTopLevel(), dlg);
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ });
+
+ JMenuItem menuSetImageBufferSize = new JMenuItem("Set Stack Size...");
+ menuSetImageBufferSize.addActionListener((ActionEvent e) -> {
+ try {
+ String ret = SwingUtils.getString(getTopLevel(), "Enter size of image buffer: ", String.valueOf(imageBufferLenght));
+ if (ret != null) {
+ this.setImageBufferSize(Integer.valueOf(ret));
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ });
+
+ JMenuItem menuSaveStack = new JMenuItem("Save Stack");
+ menuSaveStack.addActionListener((ActionEvent e) -> {
+ try {
+ saveStack();
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ });
+
+ JMenuItem menuSetROI = new JMenuItem("Set ROI...");
+ menuSetROI.addActionListener((ActionEvent e) -> {
+ renderer.abortSelection();
+ if (server != null) {
+ final Overlays.Rect selection = new Overlays.Rect(renderer.getPenMovingOverlay());
+ renderer.addListener(new RendererListener() {
+ @Override
+ public void onSelectionFinished(Renderer renderer, Overlay overlay) {
+ try {
+ renderer.setShowReticle(false);
+ Rectangle roi = overlay.isFixed() ? renderer.toImageCoord(overlay.getBounds()) : overlay.getBounds();
+ if (server.isRoiEnabled()) {
+ int[] cur = server.getRoi();
+ server.setRoi(new int[]{roi.x + cur[0], roi.y + cur[1], roi.width, roi.height});
+ } else {
+ server.setRoi(new int[]{roi.x, roi.y, roi.width, roi.height});
+ }
+ } catch (Exception ex) {
+ } finally {
+ renderer.removeListener(this);
+ }
+ }
+
+ @Override
+ public void onSelectionAborted(Renderer renderer, Overlay overlay) {
+ renderer.removeListener(this);
+ }
+ });
+ selection.setFixed(true);
+ renderer.startSelection(selection);
+ }
+ });
+
+ JMenuItem menuResetROI = new JMenuItem("Reset ROI");
+ menuResetROI.addActionListener((ActionEvent e) -> {
+ renderer.abortSelection();
+ if (server != null) {
+ try {
+ renderer.setShowReticle(false);
+ server.resetRoi();
+ } catch (IOException ex) {
+ showException(ex);
+ }
+ }
+ });
+
+ JCheckBoxMenuItem menuFrameIntegration = new JCheckBoxMenuItem("Multi-Frame", (integration != 0));
+ menuFrameIntegration.addActionListener((ActionEvent e) -> {
+ if (integration == 0) {
+ JPanel panel = new JPanel();
+ GridBagLayout layout = new GridBagLayout();
+ layout.columnWidths = new int[]{150, 50}; //Minimum width
+ layout.rowHeights = new int[]{30, 30}; //Minimum height
+ panel.setLayout(layout);
+ JCheckBox checkContinuous = new JCheckBox("");
+ checkContinuous.setSelected(true);
+ JTextField textFrames = new JTextField();
+ GridBagConstraints c = new GridBagConstraints();
+ c.gridx = 0;
+ c.gridy = 0;
+ panel.add(new JLabel("Number of frames:"), c);
+ c.gridy = 1;
+ panel.add(new JLabel("Continuous:"), c);
+ c.fill = GridBagConstraints.HORIZONTAL;
+ c.gridx = 1;
+ panel.add(checkContinuous, c);
+ c.gridy = 0;
+ panel.add(textFrames, c);
+ if (SwingUtils.showOption(getTopLevel(), "Multi-Frame Integration", panel, OptionType.OkCancel) == OptionResult.Yes) {
+ setIntegration(checkContinuous.isSelected() ? -(Integer.valueOf(textFrames.getText())) : (Integer.valueOf(textFrames.getText())));
+ }
+ } else {
+ if (SwingUtils.showOption(getTopLevel(), "Multi-Frame Integration",
+ "Do you want to disable " + ((integration < 0) ? "continuous " : "") + "multi-frame integration (" + Math.abs(integration) + ")?", OptionType.YesNo) == OptionResult.Yes) {
+ setIntegration(0);
+ }
+ }
+ });
+
+ for (Component cmp : SwingUtils.getComponentsByType(renderer.getPopupMenu(), JMenu.class)) {
+ JMenu menu = (JMenu) cmp;
+ if (menu.getText().equals("Integration")) {
+ menu.addSeparator();
+ menu.add(menuFrameIntegration);
+ }
+ }
+ renderer.getPopupMenu().addSeparator();
+ renderer.getPopupMenu().add(menuRendererConfig);
+ renderer.getPopupMenu().add(menuCameraConfig);
+ renderer.getPopupMenu().add(menuSetImageBufferSize);
+ renderer.getPopupMenu().add(menuSaveStack);
+ renderer.getPopupMenu().addSeparator();
+ renderer.getPopupMenu().add(menuCalibrate);
+ renderer.getPopupMenu().addSeparator();
+ renderer.getPopupMenu().add(menuSetROI);
+ renderer.getPopupMenu().add(menuResetROI);
+ renderer.getPopupMenu().addPopupMenuListener(new PopupMenuListener() {
+ @Override
+ public void popupMenuWillBecomeVisible(PopupMenuEvent e) {
+ menuResetROI.setEnabled(server != null);
+ menuSetROI.setEnabled(server != null);
+ menuCalibrate.setVisible(server != null);
+ menuCalibrate.setEnabled((calibrationDialolg == null) || (!calibrationDialolg.isShowing()));
+ menuSaveStack.setEnabled(imageBufferLenght > 0);
+ menuSetImageBufferSize.setEnabled(!renderer.isPaused());
+ menuFrameIntegration.setSelected(integration != 0);
+ }
+
+ @Override
+ public void popupMenuWillBecomeInvisible(PopupMenuEvent e) {
+ }
+
+ @Override
+ public void popupMenuCanceled(PopupMenuEvent e) {
+ }
+ });
+ renderer.getPopupMenu().setVisible(false);
+ buttonScale.setSelected(renderer.getShowColormapScale());
+ clearMarker();
+
+ showFit = buttonFit.isSelected();
+ showProfile = buttonProfile.isSelected();
+
+ pauseSelection.setVisible(false);
+ pauseSelection.setMinValue(1);
+ pauseSelection.addListener(new ValueSelectionListener() {
+ @Override
+ public void onValueChanged(ValueSelection origin, double value, boolean editing) {
+ if (editing && (value >= 1) && (value <= imageBuffer.size())) {
+ updatePause();
+ }
+ }
+ });
+ renderer.addListener(new RendererListener() {
+ @Override
+ public void onMoveFinished(Renderer renderer, Overlay overlay) {
+ if (overlay == marker) {
+ try {
+ onMarkerChanged();
+ } catch (IOException ex) {
+ Logger.getLogger(ScreenPanel5.class.getName()).log(Level.WARNING, null, ex);
+ }
+ }
+ }
+ });
+ if (MainFrame.isDark()) {
+ textState.setDisabledTextColor(textState.getForeground());
+ }
+
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+
+ console = (!App.hasArgument("console")) ? null : new Console() {
+ /*
+ protected void onConsoleCommand(String name, String[] pars, String trimming) throws Exception {
+ switch (name) {
+ case "cam":
+ comboCameras.setSelectedItem(tokens[1]);
+ break;
+ }
+ }*/
+ @Override
+ protected void onConsoleCommand(String command) {
+ String[] tokens = command.split(" ");
+ if ((tokens.length > 1) && tokens[0].equals("cam")) {
+ try {
+ if (!tokens[1].equals(comboCameras.getSelectedItem())) {
+ setComboTypeSelection("All");
+ updateCameraList();
+ comboCameras.setSelectedItem(tokens[1]);
+ if (!tokens[1].equals(comboCameras.getSelectedItem())) {
+ comboCameras.setSelectedItem("");
+ throw new Exception("Invalid camera name : " + tokens[1]);
+ }
+ System.out.println("Console set camera: " + tokens[1]);
+ }
+ } catch (Exception ex) {
+ System.err.println(ex);
+ }
+ } else {
+ System.err.println("Invalid command: " + command);
+ }
+ }
+ };
+ }
+
+ void setIntegration(int frames) {
+ try {
+ if (integration != frames) {
+ integration = frames;
+ if (camera != null) {
+ if (Math.abs(integration) > 1) {
+ renderer.setDevice(new ImageIntegrator(integration));
+ } else {
+ renderer.setDevice(camera);
+ }
+ synchronized (imageBuffer) {
+ currentFrame = null;
+ imageBuffer.clear();
+ }
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+
+ @Override
+ public void onStart() {
+ super.onStart();
+ updateDialogTitle();
+ if (App.hasArgument("ct")) {
+ boolean direct = App.getArgumentValue("ct").equals("0") || App.getArgumentValue("ct").equalsIgnoreCase("false");
+ buttonServer.setSelected(!direct);
+ buttonDirect.setSelected(direct);
+ }
+ if (App.hasArgument("console")) {
+ console.start();
+ }
+ }
+
+ @Override
+ public void onStop() {
+ try {
+ if (camera != null) {
+ saveCameraState();
+ camera.close();
+ camera = null;
+ server = null;
+ updateButtons();
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ try {
+ if (console != null) {
+ console.stop();
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ super.onStop();
+ }
+
+ //Overridable callbacks
+ @Override
+ public void onInitialize(int runCount) {
+ comboCameras.setEnabled(false);
+ comboType.setEnabled(false);
+ if (App.hasArgument("s")) {
+ renderer.setDevice((Source) getDevice("image"));
+ renderer.setAutoScroll(true);
+ ((Source) getDevice("image")).addListener(new ImageListener() {
+ @Override
+ public void onImage(Object o, BufferedImage bi, Data data) {
+ manageFit(bi, data);
+ manageUserOverlays(bi, data);
+ }
+
+ @Override
+ public void onError(Object o, Exception ex) {
+ }
+ }
+ );
+
+ } else {
+ usingServer = buttonServer.isSelected();
+ updateCameraList();
+ comboCameras.setEnabled(true);
+ comboType.setEnabled(true);
+ setComboCameraSelection(null);
+ setComboTypeSelection("All");
+
+ if (comboCameras.getModel().getSize() > 0) {
+ try {
+ if (App.hasArgument("cam")) {
+ setComboCameraSelection(App.getArgumentValue("cam"));
+ comboCamerasActionPerformed(null);
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ }
+ updateButtons();
+ startTimer(1000);
+ }
+
+ boolean isVisible(String camera) {
+ return ((comboType.getSelectedIndex() == 0) || (getCameraType(camera).equals(comboType.getSelectedItem())));
+ }
+
+ DefaultComboBoxModel getCameraList(boolean fromServer) throws Exception {
+ DefaultComboBoxModel model = new DefaultComboBoxModel();
+ if (fromServer) {
+ try (PipelineServer srv = newServer()) {
+ srv.initialize();
+ List cameras = srv.getCameras();
+ Collections.sort(cameras);
+ for (String camera : cameras) {
+ if (isVisible(camera)) {
+ model.addElement(camera);
+ }
+ }
+ }
+
+ } else {
+ ArrayList cameras = (ArrayList) getContext().getClassByName("SfCamera").getMethod("getCameras", new Class[]{}).invoke(null);
+ for (String camera : cameras) {
+ if (isVisible(camera)) {
+ model.addElement(camera);
+ }
+ }
+ }
+ if (App.hasArgument("cam")) {
+ String camera = App.getArgumentValue("cam");
+ if (model.getIndexOf(camera) < 0) {
+ if (isVisible(camera)) {
+ model.addElement(camera);
+ }
+ }
+ }
+ model.addElement("");
+
+ return model;
+ }
+
+ PipelineServer newServer() throws IOException {
+ if (serverUrl != null) {
+ System.out.println("Connecting to server: " + serverUrl);
+ server = new PipelineServer(CAMERA_DEVICE_NAME, serverUrl);
+ } else {
+ System.out.println("Connecting to server");
+ server = new PipelineServer(CAMERA_DEVICE_NAME);
+ }
+ updateButtons();
+ return server;
+ }
+
+ boolean updatingCameraSelection;
+
+ void setComboCameraSelection(Object selection) {
+ updatingCameraSelection = true;
+ try {
+ comboCameras.setSelectedItem(selection);
+ } finally {
+ updatingCameraSelection = false;
+ }
+ }
+
+ void setComboTypeSelection(Object selection) {
+ updatingCameraSelection = true;
+ try {
+ comboType.setSelectedItem(selection);
+ } finally {
+ updatingCameraSelection = false;
+ }
+ }
+ boolean usingServer;
+
+ void updateCameraList() {
+ try {
+ String selected = (String) comboCameras.getSelectedItem();
+ comboCameras.setModel(getCameraList(usingServer));
+ if (selected != null) {
+ if (((DefaultComboBoxModel) comboCameras.getModel()).getIndexOf(camera) < 0) {
+ setComboCameraSelection(selected);
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ } finally {
+ updateButtons();
+ }
+ }
+
+ final Object lockOverlays = new Object();
+
+ void manageFit(BufferedImage bi, Data data) {
+ Overlay[][] fo = null;
+ if ((showFit || showProfile)) {
+ try {
+ fo = getFitOverlays(data);
+ } catch (Exception ex) {
+ System.err.println(ex);
+ }
+ }
+ synchronized (lockOverlays) {
+ fo = (fo == null) ? new Overlay[][]{null, null} : fo;
+ renderer.updateOverlays(fo[0], profileOv);
+ profileOv = fo[0];
+ renderer.updateOverlays(fo[1], fitOv);
+ fitOv = fo[1];
+ }
+ }
+
+ void manageUserOverlays(BufferedImage bi, Data data) {
+ Overlay[] fo = (bi == null) ? null : getUserOverlays(data);
+ synchronized (lockOverlays) {
+ renderer.updateOverlays(fo, userOv);
+ userOv = fo;
+ }
+ }
+
+ void updateDialogTitle() {
+ if (App.isDetached()) {
+ getTopLevel().setTitle(cameraName == null ? "ScreenPanel" : cameraName);
+ }
+ }
+
+ void manageTitleOverlay() {
+ Overlay to = null;
+ if ((buttonTitle.isSelected()) && (cameraName != null)) {
+ Font font = new Font("Arial", Font.PLAIN, 28);
+ to = new Text(renderer.getPenErrorText(), cameraName, font, new Point(-SwingUtils.getTextSize(cameraName, renderer.getGraphics().getFontMetrics(font)).width - 14, 26));
+ to.setFixed(true);
+ to.setAnchor(Overlay.ANCHOR_VIEWPORT_OR_IMAGE_TOP_RIGHT);
+ }
+
+ synchronized (lockOverlays) {
+ renderer.updateOverlays(to, titleOv);
+ titleOv = to;
+ }
+ }
+
+ @Override
+ public void onStateChange(State state, State former) {
+
+ }
+
+ @Override
+ public void onExecutedFile(String fileName, Object result) {
+ }
+
+ //Callback to perform update - in event thread
+ @Override
+ protected void doUpdate() {
+ }
+
+ Thread devicesInitTask;
+
+ void setCamera(String cameraName) throws IOException, InterruptedException {
+ System.out.println("Initializing: " + cameraName);
+ parseUserOverlays();
+ errorOverlay = null;
+ lastMarkerPos = null;
+ lastFrame = null;
+ lastPipelinePars = null;
+
+ if (dataTableDialog != null) {
+ dataTableDialog.dispose();
+ dataTableDialog = null;
+ }
+ dataTableModel = null;
+
+ if (calibrationDialolg != null) {
+ calibrationDialolg.dispose();
+ calibrationDialolg = null;
+ }
+
+ boolean was_server = false;
+ if (camera != null) {
+ saveCameraState();
+ //camera.removeAllListeners();
+ was_server = (server != null);
+ camera.close();
+ camera = null;
+ server = null;
+ }
+ updateButtons();
+ instanceName = null;
+ renderer.setDevice(null);
+ renderer.setShowReticle(false);
+ renderer.removeOverlays(fitOv);
+ renderer.removeOverlays(profileOv);
+ renderer.removeOverlays(userOv);
+ renderer.clear();
+ renderer.resetZoom();
+
+ boolean changed = !String.valueOf(cameraName).equals(this.cameraName);
+ this.cameraName = cameraName;
+
+ if (changed || buttonDirect.isSelected()) {
+ spinnerThreshold.setVisible(false);
+ checkThreshold.setEnabled(false);
+ checkRotation.setEnabled(false);
+ checkGoodRegion.setEnabled(false);
+ setGoodRegionOptionsVisible(false);
+ setSlicingOptionsVisible(false);
+ setRotationOptionsVisible(false);
+ }
+ synchronized (imageBuffer) {
+ currentFrame = null;
+ imageBuffer.clear();
+ }
+ if (changed) {
+ checkBackground.setEnabled(false);
+ if ((devicesInitTask != null) && (devicesInitTask.isAlive())) {
+ devicesInitTask.interrupt();
+ }
+ if (screen != null) {
+ screen.close();
+ screen = null;
+ }
+ if (filter != null) {
+ filter.close();
+ filter = null;
+ }
+ if (renderer.isPaused()) {
+ renderer.resume();
+ removePauseOverlay();
+ pauseSelection.setVisible(false);
+ panelCameraSelection.setVisible(true);
+ }
+ }
+ manageTitleOverlay();
+ updateDialogTitle();
+
+ if (cameraName == null) {
+ return;
+ }
+
+ System.out.println("Setting camera: " + cameraName + " [" + (buttonServer.isSelected() ? "server" : "direct") + "]");
+ try {
+ if (buttonServer.isSelected()) {
+ camera = newServer();
+ camera.getConfig().flipHorizontally = false;
+ camera.getConfig().flipVertically = false;
+ camera.getConfig().rotation = 0.0;
+ camera.getConfig().roiX = 0;
+ camera.getConfig().roiY = 0;
+ camera.getConfig().roiWidth = -1;
+ camera.getConfig().roiHeight = -1;
+ } else {
+ //camera = new SfCamera(CAMERA_DEVICE_NAME, cameraName);
+ camera = (ColormapSource) getContext().getClassByName("SfCamera").getConstructor(new Class[]{String.class, String.class}).newInstance(new Object[]{CAMERA_DEVICE_NAME, cameraName});
+ }
+ camera.initialize();
+ camera.assertInitialized();
+ System.out.println("Camera initialization OK");
+ loadCameraState();
+ if (server != null) {
+ //server.start(cameraName, false);
+ String pipelineName = cameraName + pipelineSuffix;
+ instanceName = cameraName + pipelineSuffix + "1";
+ if (!server.getPipelines().contains(pipelineName)) {
+ System.out.println("Creating pipeline: " + pipelineName);
+ HashMap config = new HashMap<>();
+ config.put("camera_name", cameraName);
+ //server.createFromConfig(config, pipelineName);
+ server.savePipelineConfig(pipelineName, config);
+ }
+ server.start(pipelineName, instanceName);
+
+ updatePipelineControls();
+ checkThreshold.setEnabled(true);
+ checkRotation.setEnabled(true);
+ checkGoodRegion.setEnabled(true);
+ } else {
+ checkThreshold.setSelected(false);
+ checkRotation.setSelected(false);
+ checkGoodRegion.setSelected(false);
+ if (polling <= 0) {
+ camera.setMonitored(true);
+ } else {
+ camera.setPolling(polling);
+ }
+ camera.setBackgroundEnabled(checkBackground.isSelected());
+ }
+ updateButtons();
+ camera.getConfig().save();
+ if (Math.abs(integration) > 1) {
+ renderer.setDevice(new ImageIntegrator(integration));
+ } else {
+ renderer.setDevice(camera);
+ }
+ renderer.setAutoScroll(true);
+ //renderer.setMarker(marker);
+ clearMarker();
+ imageSize = null;
+
+ camera.addListener(new ImageListener() {
+ @Override
+ public void onImage(Object o, BufferedImage bi, Data data) {
+ if (bi != null) {
+ if ((imageSize == null) || imageSize.width != bi.getWidth() || imageSize.height != bi.getHeight()) {
+ SwingUtilities.invokeLater(new Runnable() {
+ @Override
+ public void run() {
+ if ((renderer.getMode() == RendererMode.Zoom) || (renderer.getMode() == RendererMode.Fixed)) {
+ centralizeRenderer();
+ }
+ checkReticle();
+ }
+ });
+ imageSize = new Dimension(bi.getWidth(), bi.getHeight());
+ }
+ renderer.setProfileSize(Math.min(bi.getWidth(), bi.getHeight()));
+ }
+ //renderer.setCalibration(camera.getCalibration());
+ if (!renderer.isPaused()) {
+ if (data != null) {
+ synchronized (imageBuffer) {
+ currentFrame = new Frame(data);
+ if (imageBufferLenght >= 1) {
+ imageBuffer.add(currentFrame);
+ if (imageBuffer.size() > imageBufferLenght) {
+ imageBuffer.remove(0);
+ setBufferFull(true);
+ } else {
+ setBufferFull(false);
+ }
+ } else {
+ setBufferFull(true);
+ }
+ //Update data
+ if (!renderer.isPaused()) {
+ updateStreamData();
+ }
+ updateMarker();
+ }
+ }
+ manageFit(bi, data);
+ manageUserOverlays(bi, data);
+ }
+ //updateImageData();
+ }
+
+ @Override
+ public void onError(Object o, Exception ex) {
+ //System.err.println(ex);
+ }
+ });
+
+ } catch (Exception ex) {
+ showException(ex);
+ renderer.clearOverlays();
+ updatePipelineControls();
+ if (renderer.getDevice() == null) {
+ //renderer.setZoom(1.0);
+ //renderer.setMode(RendererMode.Zoom);
+ errorOverlay = new Text(renderer.getPenErrorText(), ex.toString(), new Font("Verdana", Font.PLAIN, 12), new Point(20, 20));
+ errorOverlay.setFixed(true);
+ errorOverlay.setAnchor(Overlay.ANCHOR_VIEWPORT_TOP_LEFT);
+ renderer.addOverlay(errorOverlay);
+ }
+ } finally {
+ //checkReticle();
+ onTimer();
+ }
+ onChangeColormap(null);
+ checkBackground.setEnabled(true);
+ if (changed) {
+ boolean electrons = getCameraType(cameraName).equals(ELECTRONS_TYPE);
+ comboScreen.setModel(new DefaultComboBoxModel());
+ comboScreen.setEnabled(false);
+ comboFilter.setModel(new DefaultComboBoxModel());
+ comboFilter.setEnabled(false);
+ panelFilter.setVisible(electrons);
+ panelScreen.setVisible(electrons);
+ if (electrons) {
+ //Parallelizing initialization
+ devicesInitTask = new Thread(() -> {
+ try {
+ if (cameraName.contains("DSRM")) {
+ screen = new DiscretePositioner("CurrentScreen", cameraName + ":POSITION_SP", cameraName + ":POSITION");
+ } else {
+ screen = new DiscretePositioner("CurrentScreen", cameraName + ":SET_SCREEN1_POS", cameraName + ":GET_SCREEN1_POS");
+ }
+ screen.setMonitored(true);
+ screen.initialize();
+ DefaultComboBoxModel model = new DefaultComboBoxModel();
+ for (String pos : screen.getPositions()) {
+ model.addElement(pos);
+ }
+ comboScreen.setModel(model);
+ comboScreen.setSelectedItem(screen.read());
+
+ } catch (Exception ex) {
+ comboScreen.setModel(new DefaultComboBoxModel());
+ System.err.println(ex.getMessage());
+ screen = null;
+ }
+ comboScreen.setEnabled(screen != null);
+ valueScreen.setDevice(screen);
+
+ try {
+ filter = new DiscretePositioner("CurrentFilter", cameraName + ":SET_FILTER", cameraName + ":GET_FILTER");
+ filter.setMonitored(true);
+ filter.initialize();
+ DefaultComboBoxModel model = new DefaultComboBoxModel();
+ for (String pos : filter.getPositions()) {
+ model.addElement(pos);
+ }
+ comboFilter.setModel(model);
+ comboFilter.setSelectedItem(filter.read());
+ } catch (Exception ex) {
+ System.err.println(ex.getMessage());
+ filter = null;
+ }
+ comboFilter.setEnabled(filter != null);
+ valueFilter.setDevice(filter);
+ });
+ devicesInitTask.start();
+ }
+ }
+ }
+
+ class ImageIntegrator extends ColormapSource {
+
+ ImageIntegrator(int num) {
+ super("Image Averager", camera.getConfig());
+ boolean continuous = (num < 0);
+ final int numImages = Math.abs(num);
+
+ camera.addListener(new ImageListener() {
+ final ArrayList buffer = new ArrayList();
+ Data integration = null;
+
+ @Override
+ public void onImage(Object o, BufferedImage bi, Data data) {
+ try {
+ if (continuous) {
+ buffer.add(data);
+ if (buffer.size() >= numImages) {
+ for (Data d : buffer) {
+ process(d);
+ }
+ }
+ } else {
+ buffer.add(null); //Just to count
+ process(data);
+ }
+ } catch (Exception ex) {
+ buffer.clear();
+ integration = null;
+ ImageIntegrator.this.pushData(null);
+ ex.printStackTrace();
+ return;
+ }
+ if (buffer.size() >= numImages) {
+ if (continuous) {
+ buffer.remove(0);
+ } else {
+ buffer.clear();
+ }
+ if (integration != null) {
+ //integration.div(numImages);
+ ImageIntegrator.this.pushData(integration);
+ }
+ integration = null;
+ }
+ }
+
+ void process(Data data) {
+ if (integration == null) {
+ integration = new Data(data);
+ } else {
+ integration.sum(data);
+ }
+ }
+
+ @Override
+ public void onError(Object origin, Exception ex) {
+ }
+ });
+
+ }
+ }
+
+ boolean bufferFull = true;
+
+ void setBufferFull(boolean value) {
+ if (value != bufferFull) {
+ SwingUtilities.invokeLater(() -> {
+ buttonPause.setBackground(value ? buttonSave.getBackground() : buttonSave.getBackground().brighter());
+ });
+ bufferFull = value;
+ }
+ }
+
+ volatile Dimension imageSize;
+
+ void checkReticle() {
+ if ((renderer.getDevice() != null) && (camera != null) && (camera.getConfig().isCalibrated()) && buttonReticle.isSelected()) {
+ //renderer.setCalibration(camera.getCalibration());
+ renderer.configureReticle(new Dimension(800, 800), 200);
+ renderer.setShowReticle(true);
+ } else {
+ //renderer.setCalibration(null);
+ renderer.setShowReticle(false);
+ }
+ renderer.refresh();
+ }
+
+ void checkMarker(Point p) throws IOException {
+ if (camera != null) {
+ if (buttonMarker.isSelected()) {
+ Dimension d = renderer.getImageSize();
+ if (p == null) {
+ p = (d == null) ? new Point(renderer.getWidth() / 2, renderer.getHeight() / 2) : new Point(d.width / 2, d.height / 2);
+ }
+ Overlay ov = null;
+ marker = new Overlays.Crosshairs(renderer.getPenMarker(), p, new Dimension(100, 100));
+ marker.setMovable(true);
+ marker.setPassive(false);
+ } else {
+ marker = null;
+ }
+ renderer.setMarker(marker);
+ onMarkerChanged();
+ }
+ }
+
+ Point lastMarkerPos;
+
+ void onMarkerChanged() throws IOException {
+ lastMarkerPos = getStreamMarkerPos();
+ if (marker == null) {
+ setInstanceConfigValue("Marker", null);
+ } else {
+ setInstanceConfigValue("Marker", new int[]{marker.getPosition().x, marker.getPosition().y});
+ }
+ }
+
+ void updateMarker() {
+ try {
+ if (server != null) {
+ Point p = getStreamMarkerPos();
+ if (p != null) {
+ //To prevent a local change being overriden by a message having the old settings.
+ //TODO: This is not bullet-proof, as one can have 2 changes between 2 frames...
+ if (!p.equals(lastMarkerPos)) {
+ if (p.x == Integer.MIN_VALUE) {
+ if (buttonMarker.isSelected()) {
+ buttonMarker.setSelected(false);
+ checkMarker(null);
+ }
+ } else {
+ if (!buttonMarker.isSelected()) {
+ buttonMarker.setSelected(true);
+ checkMarker(p);
+ } else {
+ if (!p.equals(marker.getPosition())) {
+ marker.setPosition(p);
+ }
+ }
+ }
+ }
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+
+ Point getStreamMarkerPos() throws IOException {
+ //System.out.println(server.getInstanceConfig().get("Marker"));
+ Map pars = server.getProcessingParameters();
+ if (pars != null) {
+ List markerPosition = (List) pars.get("Marker");
+ if (markerPosition != null) {
+ return new Point((Integer) markerPosition.get(0), (Integer) markerPosition.get(1));
+ }
+ return new Point(Integer.MIN_VALUE, Integer.MIN_VALUE);
+ }
+ return null;
+ }
+
+ void clearMarker() {
+ marker = null;
+ renderer.setMarker(marker);
+ }
+
+ void setInstanceConfigValue(String name, Object value) throws IOException {
+ if (server != null) {
+ Map map = server.getInstanceConfig();
+ map.put(name, value);
+ server.setInstanceConfig(map);
+ }
+ }
+
+ void updateZoom() {
+ try {
+ buttonZoomStretch.setSelected(renderer.getMode() == RendererMode.Stretch);
+ buttonZoomFit.setSelected(renderer.getMode() == RendererMode.Fit);
+ if (renderer.getMode() == RendererMode.Fixed) {
+ buttonZoomNormal.setSelected(true);
+ } else if (renderer.getMode() == RendererMode.Zoom) {
+ if (renderer.getZoom() == 1) {
+ buttonZoomNormal.setSelected(true);
+ } else if (renderer.getZoom() == 0.5) {
+ buttonZoom05.setSelected(true);
+ } else if (renderer.getZoom() == 0.25) {
+ buttonZoom025.setSelected(true);
+ } else if (renderer.getZoom() == 2.0) {
+ buttonZoom2.setSelected(true);
+ } else {
+ buttonGroup1.clearSelection();
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+
+ boolean updatingColormap;
+
+ void updateColormap() {
+ updatingColormap = true;
+ try {
+ if ((camera != null) && (camera instanceof ColormapSource)) {
+ ColormapSourceConfig config = ((ColormapSource) camera).getConfig();
+ comboColormap.setSelectedItem(config.colormap);
+ if (config.isDefaultColormap()) {
+ buttonFullRange.setSelected(true);
+ } else if (config.colormapAutomatic) {
+ buttonAutomatic.setSelected(true);
+ } else {
+ buttonManual.setSelected(true);
+ }
+ btFixColormapRange.setVisible(buttonAutomatic.isSelected());
+ spinnerMin.setEnabled(buttonManual.isSelected());
+ spinnerMax.setEnabled(buttonManual.isSelected());
+ if (!Double.isNaN(config.colormapMin)) {
+ spinnerMin.setValue(Math.min(Math.max((int) config.colormapMin, 0), 65535));
+ }
+ if (!Double.isNaN(config.colormapMax)) {
+ spinnerMax.setValue(Math.min(Math.max((int) config.colormapMax, 0), 65535));
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ updatingColormap = false;
+ }
+
+ void updatePipelineProperties() {
+ goodRegion = checkGoodRegion.isSelected();
+ spinnerThreshold.setVisible(checkThreshold.isSelected());
+ setGoodRegionOptionsVisible(goodRegion);
+ slicing = goodRegion && checkSlicing.isSelected();
+ setSlicingOptionsVisible(slicing);
+ updatingServerControls = false;
+ boolean rotation = checkRotation.isSelected();
+ setRotationOptionsVisible(rotation);
+ }
+
+ boolean updatingServerControls;
+
+ void updatePipelineControls() {
+ if (server != null) {
+ updatingServerControls = true;
+ if (server.isStarted()) {
+ try {
+ checkBackground.setSelected(server.getBackgroundSubtraction());
+ Double threshold = (server.getThreshold());
+ checkThreshold.setSelected(threshold != null);
+ spinnerThreshold.setValue((threshold == null) ? 0 : threshold);
+ Map gr = (server.getGoodRegion());
+ checkGoodRegion.setSelected(gr != null);
+ if (gr != null) {
+ spinnerGrThreshold.setValue(((Number) gr.get("threshold")).doubleValue());
+ spinnerGrScale.setValue(((Number) gr.get("gfscale")).doubleValue());
+ }
+ Map rotation = server.getRotation();
+ checkRotation.setSelected(rotation != null);
+ if (rotation!=null){
+ spinnerRotationAngle.setValue(((Number) rotation.get("angle")).doubleValue());
+ spinnerRotationOrder.setValue(((Number) rotation.get("order")).intValue());
+ String mode = (String) rotation.get("mode");
+ try{
+ spinnerRotationConstant.setValue(Double.valueOf(mode));
+ spinnerRotationMode.setValue("constant");
+ } catch (Exception ex){
+ spinnerRotationConstant.setValue(0);
+ spinnerRotationMode.setValue(mode);
+ }
+ }
+
+ Map slicing = (server.getSlicing());
+ checkSlicing.setSelected(slicing != null);
+ if (slicing != null) {
+ spinnerSlNumber.setValue(((Number) slicing.get("number_of_slices")).intValue());
+ spinnerSlScale.setValue(((Number) slicing.get("scale")).doubleValue());
+ spinnerSlOrientation.setValue((String) slicing.get("orientation"));
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ updatePipelineProperties();
+ }
+ }
+
+ boolean changedPipelinePars(Map pars1, Map pars2) {
+ String[] keys = new String[]{"image_background_enable", "image_threshold", "image_good_region",
+ "threshold", "gfscale", "image_slices", "number_of_slices", "scale", "orientation"};
+ for (String key : keys) {
+ Object o1 = pars1.get(key);
+ Object o2 = pars2.get(key);
+ if (o1 == null) {
+ if (o2 != null) {
+ return true;
+ }
+ } else if (!o1.equals(o2)) {
+ return true;
+ }
+ }
+ return false;
+ }
+
+ void updatePipelineControls(Map pars) {
+ if (pars != null) {
+ updatingServerControls = true;
+ try {
+ boolean background = (boolean) pars.get("image_background_enable");
+ checkBackground.setSelected(background);
+ Double threshold = (Double) (pars.get("image_threshold"));
+ checkThreshold.setSelected(threshold != null);
+ spinnerThreshold.setValue((threshold == null) ? 0 : threshold);
+ Map gr = (Map) pars.get("image_good_region");
+ checkGoodRegion.setSelected(gr != null);
+ if (gr != null) {
+ Double value = ((Number) gr.get("threshold")).doubleValue();
+ spinnerGrThreshold.setValue(value);
+ Double scale = ((Number) gr.get("gfscale")).doubleValue();
+ spinnerGrScale.setValue(scale);
+ }
+ Map slicing = (Map) (pars.get("image_slices"));
+ checkSlicing.setSelected(slicing != null);
+ if (slicing != null) {
+ int slices = ((Number) slicing.get("number_of_slices")).intValue();
+ spinnerSlNumber.setValue(slices);
+ double scale = ((Number) slicing.get("scale")).doubleValue();
+ spinnerSlScale.setValue(scale);
+ String orientation = (String) slicing.get("orientation");
+ spinnerSlOrientation.setValue(orientation);
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ updatePipelineProperties();
+ }
+ }
+
+ void setGoodRegionOptionsVisible(boolean visible) {
+ spinnerGrThreshold.setVisible(visible);
+ labelGrThreshold.setVisible(visible);
+ spinnerGrScale.setVisible(visible);
+ labelGrScale.setVisible(visible);
+ panelSlicing.setVisible(visible);
+ }
+
+ void setSlicingOptionsVisible(boolean visible) {
+ spinnerSlNumber.setVisible(visible);
+ labelSlNumber.setVisible(visible);
+ spinnerSlScale.setVisible(visible);
+ labelSlScale.setVisible(visible);
+ spinnerSlOrientation.setVisible(visible);
+ labelSlOrientation.setVisible(visible);
+ }
+
+ void setRotationOptionsVisible(boolean visible) {
+ labelAngle.setVisible(visible);
+ labelOrder.setVisible(visible);
+ labelMode.setVisible(visible);
+ labelConstant.setVisible(visible);
+ spinnerRotationAngle.setVisible(visible);
+ spinnerRotationOrder.setVisible(visible);
+ spinnerRotationMode.setVisible(visible);
+ spinnerRotationConstant.setVisible(visible);
+ }
+
+ boolean isCameraStopped() {
+ if ((server != null) && !server.isStarted()) {
+ return true;
+ }
+ return ((camera == null) || camera.isClosed());
+ }
+
+ boolean updatingButtons;
+
+ void updateButtons() {
+ updatingButtons = true;
+ try {
+ boolean active = !isCameraStopped();//(camera != null);
+ buttonSave.setEnabled(active);
+ buttonGrabBackground.setEnabled(active);
+ buttonMarker.setEnabled(active);
+ buttonProfile.setEnabled(active);
+ buttonFit.setEnabled(active);
+ buttonReticle.setEnabled(active && camera.getConfig().isCalibrated());
+ buttonStreamData.setEnabled(active && (server != null));
+ buttonPause.setEnabled(active);
+
+ if (renderer.isPaused() != buttonPause.isSelected()) {
+ buttonPause.setSelected(renderer.isPaused());
+ buttonPauseActionPerformed(null);
+ }
+ if (renderer.getShowReticle() != buttonReticle.isSelected()) {
+ //buttonReticle.setSelected(renderer.getShowReticle());
+ }
+ if ((renderer.getMarker() == null) && buttonMarker.isSelected()) {
+ buttonMarker.setSelected(false);
+ }
+ buttonSave.setSelected(renderer.isSnapshotDialogVisible());
+
+ } finally {
+ updatingButtons = false;
+ }
+ }
+
+ Frame lastFrame = null;
+ Map lastPipelinePars = null;
+
+ @Override
+ protected void onTimer() {
+ for (Device dev : new Device[]{screen, filter}) {
+ if (dev != null) {
+ dev.request();
+ }
+ }
+
+ textState.setText((camera == null) ? "" : camera.getState().toString());
+ if (App.hasArgument("s")) {
+ try {
+ ((Source) getDevice("image")).initialize();
+ } catch (IOException ex) {
+ Logger.getLogger(getClass().getName()).log(Level.SEVERE, null, ex);
+ } catch (InterruptedException ex) {
+ Logger.getLogger(getClass().getName()).log(Level.SEVERE, null, ex);
+ }
+ }
+ updateZoom();
+ updateColormap();
+ updateButtons();
+ checkHistogram.setSelected((histogramDialog != null) && (histogramDialog.isShowing()));
+ buttonScale.setSelected(renderer.getShowColormapScale());
+ try {
+ Frame frame = getCurrentFrame();
+ if (frame != lastFrame) {
+ lastFrame = frame;
+ if (frame != null) {
+ Map pars = getProcessingParameters(frame.cache);
+ if ((lastPipelinePars == null) || changedPipelinePars(pars, lastPipelinePars)) {
+ //System.out.println("Update pipeline: " + pars);
+ lastPipelinePars = pars;
+ updatePipelineControls(pars);
+ }
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+
+ Pen penFit = new Pen(new Color(192, 105, 0), 0);
+ Pen penCross = new Pen(new Color(192, 105, 0), 0);
+ Pen penSlices = new Pen(Color.CYAN.darker(), 1);
+
+ Frame getCurrentFrame() {
+ if ((imageBufferLenght > 1) && (renderer.isPaused())) {
+ int index = ((int) pauseSelection.getValue()) - 1;
+ synchronized (imageBuffer) {
+ return (index < imageBuffer.size()) ? imageBuffer.get(index) : null;
+ }
+ }
+ return currentFrame;
+ }
+
+ Frame getFrame(Data data) {
+ synchronized (imageBuffer) {
+ for (Frame f : imageBuffer) {
+ if (f.data == data) {
+ return f;
+ }
+ }
+ }
+ return null;
+ }
+
+ void setImageBufferSize(int size) {
+ if (renderer.isPaused()) {
+ throw new RuntimeException("Cannot change buffer size whn paused");
+ }
+ synchronized (imageBuffer) {
+ imageBufferLenght = size;
+ imageBuffer.clear();
+ }
+
+ }
+
+ Overlay[][] getFitOverlays(Data data) {
+ Overlays.Polyline hgaussian = null;
+ Overlays.Polyline vgaussian = null;
+ Overlays.Polyline hprofile = null;
+ Overlays.Polyline vprofile = null;
+ Double xMean = null, xSigma = null, xNorm = null, xCom = null, xRms = null;
+ Double yMean = null, ySigma = null, yNorm = null, yCom = null, yRms = null;
+ double[] pX = null, pY = null, gX = null, gY = null;
+ PointDouble[] sliceCenters = null;
+ if (data != null) {
+ int height = data.getHeight();
+ int width = data.getWidth();
+ int profileSize = renderer.getProfileSize();
+ ImageData id = null;
+ if ((useServerStats) && (server != null)) {
+ try {
+ id = getFrame(data);
+ if (id == null) {
+ return null;
+ }
+ xMean = id.x_fit_mean;
+ xSigma = id.x_fit_standard_deviation;
+ yMean = id.y_fit_mean;
+ ySigma = id.y_fit_standard_deviation;
+ gX = id.x_fit_gauss_function;
+ gY = id.y_fit_gauss_function;
+ pX = id.x_profile;
+ pY = id.y_profile;
+ xCom = id.x_center_of_mass;
+ xRms = id.x_rms;
+ yCom = id.y_center_of_mass;
+ yRms = id.y_rms;
+ sliceCenters = id.sliceCenters;
+
+ profileSize /= 4;
+ if (pX != null) {
+ int[] xp = Arr.indexesInt(pX.length);
+ int[] xg = xp;
+ int[] yp = new int[pX.length];
+ int[] yg = new int[pX.length];
+
+ List l = Arrays.asList((Double[]) Convert.toWrapperArray(pX));
+ double minProfile = Collections.min(l);
+ double maxProfile = Collections.max(l);
+ double rangeProfile = maxProfile - minProfile;
+ double minGauss = minProfile;
+ double rangeGauss = rangeProfile;
+ //If not good region, range of profile and fit are similar so save this calcultion
+ if (goodRegion && id.gr_size_x > 0) {
+ l = Arrays.asList((Double[]) Convert.toWrapperArray(Arrays.copyOfRange(gX, id.gr_pos_x, id.gr_pos_x + id.gr_size_x)));
+ minGauss = Collections.min(l);
+ rangeGauss = Collections.max(l) - minGauss;
+ }
+
+ for (int i = 0; i < xp.length; i++) {
+ if (gX != null) {
+ yg[i] = (int) (height - 1 - (((gX[i] - minGauss) / rangeGauss) * profileSize));
+ }
+ yp[i] = (int) (height - 1 - (((pX[i] - minProfile) / rangeProfile) * profileSize));
+ }
+
+ if (goodRegion && id.gr_size_x > 0) {
+ xg = Arrays.copyOfRange(xg, id.gr_pos_x, id.gr_pos_x + id.gr_size_x);
+ yg = Arrays.copyOfRange(yg, id.gr_pos_x, id.gr_pos_x + id.gr_size_x);
+ }
+
+ vgaussian = new Overlays.Polyline(penFit, xg, yg);
+ vprofile = new Overlays.Polyline(renderer.getPenProfile(), xp, yp);
+ }
+
+ if (pY != null) {
+ int[] xp = new int[pY.length];
+ int[] xg = new int[pY.length];
+ int[] yp = Arr.indexesInt(pY.length);
+ int[] yg = yp;
+
+ List l = Arrays.asList((Double[]) Convert.toWrapperArray(pY));
+ double minProfile = Collections.min(l);
+ double maxProfile = Collections.max(l);
+ double rangeProfile = maxProfile - minProfile;
+ double minGauss = minProfile;
+ double rangeGauss = rangeProfile;
+ //If not good region, range of profile and fit are similar so save this calcultion
+ if (goodRegion && id.gr_size_y > 0) {
+ l = Arrays.asList((Double[]) Convert.toWrapperArray(Arrays.copyOfRange(gY, id.gr_pos_y, id.gr_pos_y + id.gr_size_y)));
+ minGauss = Collections.min(l);
+ rangeGauss = Collections.max(l) - minGauss;
+ }
+
+ for (int i = 0; i < xp.length; i++) {
+ if (gY != null) {
+ xg[i] = (int) (((gY[i] - minGauss) / rangeGauss) * profileSize);
+ }
+ xp[i] = (int) (((pY[i] - minProfile) / rangeProfile) * profileSize);
+ }
+
+ if (goodRegion && id.gr_size_y > 0) {
+ xg = Arrays.copyOfRange(xg, id.gr_pos_y, id.gr_pos_y + id.gr_size_y);
+ yg = Arrays.copyOfRange(yg, id.gr_pos_y, id.gr_pos_y + id.gr_size_y);
+ }
+ hgaussian = new Overlays.Polyline(penFit, xg, yg);
+ hprofile = new Overlays.Polyline(renderer.getPenProfile(), xp, yp);
+ }
+ } catch (Exception ex) {
+ System.err.println(ex.getMessage());
+ return null;
+ }
+ } else {
+ ArrayProperties properties = data.getProperties();
+ double maxPlot = properties.max;
+ double minPlot = properties.min;
+ double rangePlot = maxPlot - minPlot;
+
+ if (rangePlot <= 0) {
+ return null;
+ }
+ if (renderer.getCalibration() != null) {
+ try {
+ double[] sum = data.integrateVertically(true);
+ double[] saux = new double[sum.length];
+ int[] p = new int[sum.length];
+ double[] x_egu = renderer.getCalibration().getAxisX(sum.length);
+ double[] comRms = getComRms(sum, x_egu);
+ xCom = comRms[0];
+ xRms = comRms[1];
+ int[] x = Arr.indexesInt(sum.length);
+ DescriptiveStatistics stats = new DescriptiveStatistics(sum);
+ double min = stats.getMin();
+ for (int i = 0; i < sum.length; i++) {
+ saux[i] = sum[i] - min;
+ }
+ if (showFit) {
+ double[] gaussian = fitGaussian(saux, x);
+ if (gaussian != null) {
+ if ((gaussian[2] < sum.length * 0.45)
+ && (gaussian[2] > 2)
+ && (gaussian[0] > min * 0.03)) {
+ xNorm = gaussian[0];
+ xMean = gaussian[1];
+ xSigma = gaussian[2];
+ double[] fit = getFitFunction(gaussian, x);
+ int[] y = new int[x.length];
+ for (int i = 0; i < x.length; i++) {
+ y[i] = (int) (height - 1 - ((((fit[i] + min) / height - minPlot) / rangePlot) * profileSize));
+ }
+ vgaussian = new Overlays.Polyline(penFit, x, y);
+ }
+ }
+ }
+ if (showProfile) {
+ for (int i = 0; i < x.length; i++) {
+ p[i] = (int) (height - 1 - (((sum[i] / height - minPlot) / rangePlot) * profileSize));
+ }
+ vprofile = new Overlays.Polyline(renderer.getPenProfile(), x, p);
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+
+ try {
+ double[] sum = data.integrateHorizontally(true);
+ double[] saux = new double[sum.length];
+ int[] p = new int[sum.length];
+ double[] y_egu = renderer.getCalibration().getAxisY(sum.length);
+ double[] comRms = getComRms(sum, y_egu);
+ yCom = comRms[0];
+ yRms = comRms[1];
+ int[] x = Arr.indexesInt(sum.length);
+ DescriptiveStatistics stats = new DescriptiveStatistics(sum);
+ double min = stats.getMin();
+ for (int i = 0; i < sum.length; i++) {
+ saux[i] = sum[i] - min;
+ }
+
+ if (showFit) {
+ double[] gaussian = fitGaussian(saux, x);
+ if (gaussian != null) {
+ //Only aknowledge beam fully inside the image and peak over 3% of min
+ if ((gaussian[2] < sum.length * 0.45)
+ && (gaussian[2] > 2)
+ && (gaussian[0] > min * 0.03)) {
+ yNorm = gaussian[0];
+ yMean = gaussian[1];
+ ySigma = gaussian[2];
+ double[] fit = getFitFunction(gaussian, x);
+
+ int[] y = new int[x.length];
+ for (int i = 0; i < x.length; i++) {
+ y[i] = (int) ((((fit[i] + min) / width - minPlot) / rangePlot) * profileSize);
+ }
+ hgaussian = new Overlays.Polyline(penFit, y, x);
+ }
+ }
+ }
+ if (showProfile) {
+ for (int i = 0; i < x.length; i++) {
+ p[i] = (int) (((sum[i] / width - minPlot) / rangePlot) * profileSize);
+ }
+ hprofile = new Overlays.Polyline(renderer.getPenProfile(), p, x);
+ }
+
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ if (xSigma != null) {
+ xSigma *= renderer.getCalibration().getScaleX();
+ }
+ if (ySigma != null) {
+ ySigma *= renderer.getCalibration().getScaleY();
+ }
+ if (xMean != null) {
+ xMean = data.getX((int) Math.round(xMean));
+ }
+ if (yMean != null) {
+ yMean = data.getY((int) Math.round(yMean));
+ }
+ }
+ }
+ final String units = (renderer.getCalibration() != null) ? "\u00B5m" : "px";
+ final String fmt = "%7.1f" + units;
+ Overlays.Text textCom = null;
+ Overlay[] pOv = null, fOv = null;
+ Font fontInfoText = new Font(Font.MONOSPACED, 0, 14);
+ Point textPosition = new Point(12, 20);
+ if (showProfile) {
+ if ((xCom != null) && (yCom != null)) {
+ String text = String.format("com x: m=" + fmt + " \u03C3=" + fmt + "\ncom y: m=" + fmt + " \u03C3=" + fmt, xCom, xRms, yCom, yRms);
+ textCom = new Overlays.Text(renderer.getPenProfile(), text, fontInfoText, textPosition);
+ textCom.setFixed(true);
+ textCom.setAnchor(Overlay.ANCHOR_VIEWPORT_TOP_LEFT);
+ }
+ pOv = new Overlay[]{hprofile, vprofile, textCom};
+ textPosition = new Point(textPosition.x, textPosition.y + 34);
+ }
+ if (showFit) {
+ Overlays.Crosshairs cross = null;
+ Overlays.Text textFit = null;
+ if ((xMean != null) && (yMean != null)) {
+ String text = String.format("fit x: m=" + fmt + " \u03C3=" + fmt + "\nfit y: m=" + fmt + " \u03C3=" + fmt, xMean, xSigma, yMean, ySigma);
+ textFit = new Overlays.Text(penFit, text, fontInfoText, textPosition);
+ textFit.setFixed(true);
+ textFit.setAnchor(Overlay.ANCHOR_VIEWPORT_TOP_LEFT);
+ Point center = new Point(xMean.intValue(), yMean.intValue());
+ if (renderer.getCalibration() != null) {
+ center = renderer.getCalibration().convertToImagePosition(new PointDouble(xMean, yMean));
+ xSigma /= renderer.getCalibration().getScaleX();
+ ySigma /= renderer.getCalibration().getScaleY();
+ }
+ cross = new Overlays.Crosshairs(penCross, center, new Dimension(Math.abs(2 * xSigma.intValue()), 2 * Math.abs(ySigma.intValue())));
+ }
+ textPosition = new Point(textPosition.x, textPosition.y + 34);
+ fOv = new Overlay[]{hgaussian, vgaussian, cross, textFit};
+
+ if (goodRegion && (id != null)) {
+ try {
+ double[] x = id.gr_x_axis;
+ double[] y = id.gr_y_axis;
+ Overlays.Rect goodRegionOv = new Overlays.Rect(new Pen(penFit.getColor(), 0, Pen.LineStyle.dotted));
+ goodRegionOv.setCalibration(renderer.getCalibration());
+ goodRegionOv.setPosition(new Point(id.gr_pos_x, id.gr_pos_y));
+ goodRegionOv.setSize(new Dimension(id.gr_x_axis.length, id.gr_y_axis.length));
+ fOv = Arr.append(fOv, goodRegionOv);
+
+ if (slicing) {
+ if (sliceCenters != null) {
+ for (PointDouble sliceCenter : sliceCenters) {
+ Overlays.Crosshairs center = new Overlays.Crosshairs(penSlices);
+ center.setCalibration(renderer.getCalibration());
+ center.setAbsolutePosition(sliceCenter);
+ center.setSize(new Dimension(10, 10));
+ fOv = Arr.append(fOv, center);
+ }
+ if (sliceCenters.length > 1) {
+ double[] fit = fitPolynomial(sliceCenters, 1);
+ double angle = Math.toDegrees(Math.atan(fit[1]));
+ Overlays.Text text = new Overlays.Text(penSlices, String.format("slice: \u03B8= %5.1fdeg", angle), fontInfoText, textPosition);
+ text.setFixed(true);
+ text.setAnchor(Overlay.ANCHOR_VIEWPORT_TOP_LEFT);
+ fOv = Arr.append(fOv, text);
+ }
+ }
+ }
+ } catch (Exception ex) {
+ }
+ }
+
+ }
+ return new Overlay[][]{pOv, fOv};
+ }
+ return null;
+ }
+
+ class UserOverlay {
+
+ String name;
+ Overlay obj;
+ String[] channels;
+ }
+ ArrayList userOverlayConfig;
+
+ void parseUserOverlays() {
+ Properties userOverlays = new Properties();
+ userOverlayConfig = new ArrayList<>();
+ if (userOverlaysConfigFile != null) {
+ try {
+ try (FileInputStream in = new FileInputStream(getContext().getSetup().expandPath(userOverlaysConfigFile))) {
+ userOverlays.load(in);
+
+ for (String name : userOverlays.stringPropertyNames()) {
+ String val = userOverlays.getProperty(name);
+ try {
+ UserOverlay uo = new UserOverlay();
+ uo.name = name;
+ String type = val.substring(0, val.indexOf("(")).trim();
+ String pars = val.substring(val.indexOf("(") + 1, val.lastIndexOf(")")).trim();
+ String[] tokens = pars.split(",");
+ for (int i = 0; i < tokens.length; i++) {
+ tokens[i] = tokens[i].trim();
+ }
+ Color color = Color.GRAY;
+ try {
+ color = (Color) Color.class.getField(tokens[tokens.length - 1].toUpperCase()).get(null);
+ } catch (Exception ex) {
+ }
+ Pen pen = new Pen(color);
+ try {
+ String[] penTokens = tokens[tokens.length - 1].split(":");
+ color = (Color) Color.class.getField(penTokens[0].toUpperCase()).get(null);
+ int width = Integer.valueOf(penTokens[1]);
+ Pen.LineStyle style = Pen.LineStyle.valueOf(penTokens[2]);
+ pen = new Pen(color, width, style);
+ } catch (Exception ex) {
+ }
+ switch (type) {
+ case "Point":
+ uo.obj = new Overlays.Crosshairs();
+ uo.obj.setSize(new Dimension(Integer.valueOf(tokens[2]), Integer.valueOf(tokens[3])));
+ break;
+ case "Line":
+ uo.obj = new Overlays.Line();
+ break;
+ case "Arrow":
+ uo.obj = new Overlays.Arrow();
+ break;
+ case "Rect":
+ uo.obj = new Overlays.Rect();
+ break;
+ case "Ellipse":
+ uo.obj = new Overlays.Ellipse();
+ break;
+ case "Polyline":
+ uo.obj = new Overlays.Polyline();
+ break;
+ }
+ if (type.equals("Polyline") || type.equals("Point")) {
+ uo.channels = new String[]{tokens[0], tokens[1]};
+ } else {
+ uo.channels = new String[]{tokens[0], tokens[1], tokens[2], tokens[3]};
+ }
+ uo.obj.setPen(pen);
+ userOverlayConfig.add(uo);
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ }
+
+ Overlay[] getUserOverlays(Data data) {
+ ArrayList ret = new ArrayList<>();
+ if (server != null) {
+ ImageData id = getFrame(data);
+ for (UserOverlay uo : userOverlayConfig) {
+ try {
+ Overlay ov = uo.obj;
+ //Overlay ov = (Overlay)uo.cls.newInstance();
+ ov.setCalibration(renderer.getCalibration());
+ boolean valid = false;
+ if (ov instanceof Overlays.Polyline) {
+ double[] x = (uo.channels[0].equals("null")) ? null : id.getDoubleArray(uo.channels[0]);
+ double[] y = (uo.channels[1].equals("null")) ? null : id.getDoubleArray(uo.channels[1]);
+ if ((x != null) || (y != null)) {
+ if (x == null) {
+ x = (renderer.getCalibration() == null) ? Arr.indexesDouble(y.length) : renderer.getCalibration().getAxisX(y.length);
+ }
+ if (y == null) {
+ y = (renderer.getCalibration() == null) ? Arr.indexesDouble(x.length) : renderer.getCalibration().getAxisY(x.length);
+ }
+ ((Overlays.Polyline) ov).updateAbsolute(x, y);
+ valid = true;
+ }
+ } else {
+ Double x = id.getDouble(uo.channels[0]);
+ Double y = id.getDouble(uo.channels[1]);
+ if ((x != null) && (y != null)) {
+ PointDouble position = new PointDouble(x, y);
+ ov.setAbsolutePosition(position);
+ if (!(ov instanceof Overlays.Crosshairs)) {
+ Double x2 = id.getDouble(uo.channels[2]);
+ Double y2 = id.getDouble(uo.channels[3]);
+ if ((x != null) && (y != null)) {
+ DimensionDouble size = new DimensionDouble(x2 - position.x, y2 - position.y);
+ ov.setAbsoluteSize(size);
+ valid = true;
+ }
+ } else {
+ valid = true;
+ }
+ }
+ }
+ if (valid) {
+ ret.add(ov);
+ }
+ } catch (Exception ex) {
+ //ex.printStackTrace();
+ }
+ }
+ }
+ return ret.toArray(new Overlay[0]);
+ }
+
+ double[] getComRms(double[] arr, double[] x) {
+ if (arr != null) {
+ double xmd = 0;
+ double xmd2 = 0;
+ double total = 0;
+ for (int i = 0; i < arr.length; i++) {
+ double v = (arr[i] * x[i]);
+ xmd += v;
+ xmd2 += (v * x[i]);
+ total += arr[i];
+ }
+ if (total > 0) {
+ double com = xmd / total;
+ double com2 = xmd2 / total;
+ double rms = Math.sqrt(Math.abs(com2 - com * com));
+ return new double[]{com, rms};
+ }
+ }
+ return new double[]{Double.NaN, Double.NaN};
+ }
+
+ double[] fitGaussianScript(int[] y, int[] x) {
+ ScriptManager sm = Context.getInstance().getScriptManager();
+ ArrayProperties pY = ArrayProperties.get(y);
+ sm.setVar("y", y);
+ sm.setVar("x", x);
+ InterpreterResult r = sm.eval("r = fit_gaussians(y, x, [" + pY.maxIndex + ",])");
+ if (r.exception != null) {
+ r.exception.printStackTrace();
+ } else {
+ List ret = (List) sm.getVar("r");
+ if ((ret != null) && (ret.size() == 1) && (ret.get(0) instanceof List) && (((List) (ret.get(0))).size() == 3)) {
+ double norm = (Double) ((List) ret.get(0)).get(0);
+ double mean = (Double) ((List) ret.get(0)).get(1);
+ double sigma = (Double) ((List) ret.get(0)).get(2);
+ return new double[]{norm, mean, sigma};
+ }
+ }
+ return null;
+ }
+
+ double[] fitGaussian(double[] y, int[] x) {
+ try {
+ ArrayProperties pY = ArrayProperties.get(y);
+ GaussianCurveFitter fitter = GaussianCurveFitter.create().withStartPoint(new double[]{(pY.max - pY.min) / 2, x[pY.maxIndex], 1.0}).withMaxIterations(1000);
+ ArrayList values = new ArrayList<>();
+ for (int i = 0; i < y.length; i++) {
+ values.add(new WeightedObservedPoint(1.0, x[i], y[i]));
+ }
+ return fitter.fit(values);
+ } catch (Exception ex) {
+ return null;
+ }
+
+ }
+
+ double[] fitPolynomial(PointDouble[] points, int order) {
+ double[] y = new double[points.length];
+ double[] x = new double[points.length];
+ for (int i = 0; i < points.length; i++) {
+ x[i] = points[i].x;
+ y[i] = points[i].y;
+ }
+ return fitPolynomial(y, x, order);
+ }
+
+ double[] fitPolynomial(double[] y, double[] x, int order) {
+ try {
+ ArrayProperties pY = ArrayProperties.get(y);
+ PolynomialCurveFitter fitter = PolynomialCurveFitter.create(order).withMaxIterations(1000);
+ ArrayList values = new ArrayList<>();
+ for (int i = 0; i < y.length; i++) {
+ values.add(new WeightedObservedPoint(1.0, x[i], y[i]));
+ }
+ return fitter.fit(values);
+ } catch (Exception ex) {
+ return null;
+ }
+
+ }
+
+ double[] getFitFunction(double[] pars, int[] x) {
+ double[] fit = new double[x.length];
+ Gaussian g = new Gaussian(pars[0], pars[1], pars[2]);
+ for (int i = 0; i < x.length; i++) {
+ fit[i] = g.value(x[i]);
+ }
+ return fit;
+ }
+
+ void setHistogramVisible(boolean value) {
+ if (value) {
+ if ((histogramDialog == null) || (!histogramDialog.isShowing())) {
+ Histogram histogram = new Histogram(true);
+ histogram.setRenderer(renderer);
+ histogramDialog = SwingUtils.showDialog(SwingUtils.getWindow(renderer), "Histogram", null, histogram);
+ renderer.refresh();
+ }
+ } else {
+ if (histogramDialog != null) {
+ histogramDialog.setVisible(false);
+ histogramDialog = null;
+ }
+ }
+ }
+
+ void setLaserState(int bunch, boolean value) throws Exception {
+ System.out.println("Setting laser state: " + value + " - bunch" + bunch);
+ //Epics.putq("SIN-TIMAST-TMA:Beam-Las-Delay-Sel", value ? 0 : 1);
+ if ((bunch<=0) || (bunch==1)){
+ Epics.putq("SWISSFEL-STATUS:Bunch-1-OnDelay-Sel", value ? 0 : 1);
+ }
+ if ((bunch<=0) || (bunch==2)){
+ Epics.putq("SWISSFEL-STATUS:Bunch-2-OnDelay-Sel", value ? 0 : 1);
+ }
+
+ Epics.putq("SIN-TIMAST-TMA:Beam-Apply-Cmd.PROC", 1);
+ Thread.sleep(3000);
+ }
+
+ boolean getLaserState(int bunch) throws Exception {
+ //return (Epics.get("SIN-TIMAST-TMA:Beam-Las-Delay-Sel", Integer.class) == 0);
+ if (bunch<=0){
+ return getLaserState(1) && getLaserState(2);
+ }
+ if (bunch==2){
+ return (Epics.get("SWISSFEL-STATUS:Bunch-2-OnDelay-Sel", Integer.class) == 0);
+ }
+ return (Epics.get("SWISSFEL-STATUS:Bunch-1-OnDelay-Sel", Integer.class) == 0);
+ }
+
+ void elog(String logbook, String title, String message, String[] attachments) throws Exception {
+ String domain = "";
+ String category = "Info";
+ String entry = "";
+ StringBuffer cmd = new StringBuffer();
+
+ cmd.append("G_CS_ELOG_add -l \"").append(logbook).append("\" ");
+ cmd.append("-a \"Author=ScreenPanel\" ");
+ cmd.append("-a \"Type=pshell\" ");
+ cmd.append("-a \"Entry=").append(entry).append("\" ");
+ cmd.append("-a \"Title=").append(title).append("\" ");
+ cmd.append("-a \"Category=").append(category).append("\" ");
+ cmd.append("-a \"Domain=").append(domain).append("\" ");
+ for (String attachment : attachments) {
+ cmd.append("-f \"").append(attachment).append("\" ");
+ }
+ cmd.append("-n 1 ");
+ cmd.append("\"").append(message).append("\" ");
+ System.out.println(cmd.toString());
+
+ final Process process = Runtime.getRuntime().exec(new String[]{"bash", "-c", cmd.toString()});
+ new Thread(() -> {
+ try {
+ process.waitFor();
+ int bytes = process.getInputStream().available();
+ byte[] arr = new byte[bytes];
+ process.getInputStream().read(arr, 0, bytes);
+ System.out.println(new String(arr));
+ bytes = process.getErrorStream().available();
+ arr = new byte[bytes];
+ process.getErrorStream().read(arr, 0, bytes);
+ System.err.println(new String(arr));
+ } catch (Exception ex) {
+ System.err.println(ex);
+ }
+ }).start();
+ }
+
+ void centralizeRenderer() {
+ Point center = null;
+ Dimension size = renderer.getImageSize();
+ double zoom = (renderer.getMode() == RendererMode.Fixed) ? 1.0 : renderer.getZoom();
+ if (renderer.getCalibration() != null) {
+ center = renderer.getCalibration().getCenter();
+ } else if (size != null) {
+ center = new Point(size.width / 2, size.height / 2);
+ }
+ if (center != null) {
+ Point topleft = new Point(Math.max((int) (center.x - renderer.getWidth() / 2 / zoom), 0),
+ Math.max((int) (center.y - renderer.getHeight() / 2 / zoom), 0));
+ renderer.setViewPosition(topleft);
+ }
+ }
+
+ void updatePause() {
+ int index = ((int) pauseSelection.getValue()) - 1;
+ synchronized (imageBuffer) {
+ if (index < imageBuffer.size()) {
+ Data data = imageBuffer.get(index).data;
+ long pid = imageBuffer.get(index).cache.getPulseId();
+ BufferedImage image = camera.generateImage(data);
+ renderer.setImage(renderer.getOrigin(), image, data);
+
+ String text = "PID: " + pid;
+ if (imagePauseOverlay == null) {
+ Font font = new Font("Verdana", Font.PLAIN, 12);
+ Dimension d = SwingUtils.getTextSize(text, renderer.getFontMetrics(font));
+ imagePauseOverlay = new Text(renderer.getPenErrorText(), "", font, new Point(-20 - d.width, 42));
+ imagePauseOverlay.setFixed(true);
+ imagePauseOverlay.setAnchor(Overlay.ANCHOR_VIEWPORT_OR_IMAGE_TOP_RIGHT);
+ renderer.addOverlay(imagePauseOverlay);
+ }
+ //imagePauseOverlay.update(Chrono.getTimeStr(data.getTimestamp(), "HH:mm:ss.SSS"));
+ imagePauseOverlay.update(text);
+ manageFit(image, data);
+ manageUserOverlays(image, data);
+ }
+ }
+ updateStreamData();
+ }
+
+ void removePauseOverlay() {
+ renderer.removeOverlay(imagePauseOverlay);
+ imagePauseOverlay = null;
+ }
+
+ void saveSnapshot() throws Exception {
+ boolean paused = isPaused();
+ try{
+ if (!paused){
+ setPaused(true);
+ }
+ String snapshotFile = null;
+ synchronized (imageBuffer) {
+ Frame frame = getCurrentFrame();
+ if (frame == null) {
+ throw new Exception("No current image");
+ }
+ ArrayList frames = new ArrayList<>();
+ frames.add(frame);
+ this.saveFrames(cameraName + "_camera_snapshot", frames);
+
+ //Enforce the same timestamp to data & image files.
+ snapshotFile = getContext().getExecutionPars().getPath() + ".png";
+ //renderer.saveSnapshot(snapshotFile, "png", true);
+ ImageBuffer.saveImage(SwingUtils.createImage(renderer), snapshotFile, "png");
+ }
+
+ JPanel panel = new JPanel();
+ GridBagLayout layout = new GridBagLayout();
+ layout.columnWidths = new int[]{0, 180}; //Minimum width
+ layout.rowHeights = new int[]{30, 30, 30}; //Minimum height
+ panel.setLayout(layout);
+ JComboBox comboLogbook = new JComboBox(new String[]{"SwissFEL commissioning data", "SwissFEL commissioning"});
+ JTextField textComment = new JTextField();
+ GridBagConstraints c = new GridBagConstraints();
+ c.gridx = 0;
+ c.gridy = 0;
+ panel.add(new JLabel("Data file:"), c);
+ c.gridy = 1;
+ panel.add(new JLabel("Logbook:"), c);
+ c.gridy = 2;
+ panel.add(new JLabel("Comment:"), c);
+ c.fill = GridBagConstraints.HORIZONTAL;
+ c.gridx = 1;
+ panel.add(textComment, c);
+ c.gridy = 1;
+ panel.add(comboLogbook, c);
+ c.gridy = 0;
+ panel.add(new JLabel(getContext().getExecutionPars().getPath()), c);
+
+ if (SwingUtils.showOption(getTopLevel(), "Success", panel, OptionType.OkCancel) == OptionResult.Yes) {
+ StringBuilder message = new StringBuilder();
+ message.append("Camera: ").append(cameraName).append(" (").
+ append((server != null) ? "server" : "direct").append(")").append("\n");
+ message.append("Screen: ").append(String.valueOf(valueScreen.getLabel().getText())).append("\n");
+ message.append("Filter: ").append(String.valueOf(valueFilter.getLabel().getText())).append("\n");
+ message.append("Data file: ").append(getContext().getExecutionPars().getPath()).append("\n");
+ message.append("Comment: ").append(textComment.getText()).append("\n");
+ //Add slicing message
+ if ((fitOv != null) && (fitOv.length > 5) && (fitOv[fitOv.length - 1] instanceof Overlays.Text)) {
+ Overlays.Text text = (Overlays.Text) fitOv[fitOv.length - 1];
+ message.append(text.getText()).append("\n");
+ }
+ elog((String) comboLogbook.getSelectedItem(), "ScreenPanel Snapshot", message.toString(), new String[]{snapshotFile});
+ }
+ } finally{
+ if (!paused){
+ setPaused(false);
+ }
+ }
+ }
+
+ void saveStack() throws Exception {
+ synchronized (imageBuffer) {
+ saveFrames(cameraName + "_camera_stack", imageBuffer);
+ }
+ SwingUtils.showMessage(getTopLevel(), "Success", "Generated data file:\n" + getContext().getExecutionPars().getPath());
+ }
+
+ public static String getCameraType(String name) {
+ if (name == null) {
+ return "";
+ }
+ for (String s : new String[]{"LCAM"}) {
+ if (name.contains(s)) {
+ return LASER_TYPE;
+ }
+ }
+ for (String s : new String[]{"DSCR", "DSRM", "DLAC"}) {
+ if (name.contains(s)) {
+ return ELECTRONS_TYPE;
+ }
+ }
+ for (String s : new String[]{"PROF", "PPRM", "PSSS", "PSCR", "PSRD"}) {
+ if (name.contains(s)) {
+ return PHOTONICS_TYPE;
+ }
+ }
+ return "Unknown";
+ }
+
+ public Map getProcessingParameters(StreamValue value) throws IOException {
+ return (Map) JsonSerializer.decode(value.getValue("processing_parameters").toString(), Map.class);
+ }
+
+ void saveFrames(String name, ArrayList frames) throws IOException {
+ ArrayList values = new ArrayList<>();
+ for (Frame frame : frames) {
+ values.add(frame.cache);
+ }
+ saveImages(name, values);
+ }
+
+ void saveImages(String name, ArrayList images) throws IOException {
+ int depth = images.size();
+ if (depth == 0) {
+ return;
+ }
+ StreamValue first = images.get(0);
+ String pathRoot = "/camera1/";
+ String pathImage = pathRoot + "image";
+ String pathPid = pathRoot + "pulse_id";
+ String pathTimestampStr = pathRoot + "timestamp_str";
+ Map processingPars = getProcessingParameters(first);
+ String camera = (String) processingPars.get("camera_name");
+ String type = getCameraType(camera);
+
+ int width = ((Number) first.getValue("width")).intValue();
+ int height = ((Number) first.getValue("height")).intValue();
+ Class dataType = first.getValue("image").getClass().getComponentType();
+
+ getContext().setExecutionPars(name);
+ DataManager dm = getContext().getDataManager();
+
+ //Create tables
+ dm.createDataset(pathImage, dataType, new int[]{depth, height, width});
+ dm.createDataset(pathPid, Long.class, new int[]{depth});
+ dm.createDataset(pathTimestampStr, String.class, new int[]{depth});
+ for (String id : first.getIdentifiers()) {
+ Object val = first.getValue(id);
+ if (id.equals("image")) {
+ } else if (id.equals("processing_parameters")) {
+ Map pars = getProcessingParameters(first);
+ for (String key : pars.keySet()) {
+ if ((pars.get(key) != null) && (pars.get(key) instanceof Map)) {
+ for (Object k : ((Map) pars.get(key)).keySet()) {
+ Object v = ((Map) pars.get(key)).get(k);
+ dm.setAttribute(pathImage, key + " " + k, (v == null) ? "" : v);
+ }
+ } else {
+ Object value = pars.get(key);
+ if (value == null) {
+ value = "";
+ } else if (value instanceof List) {
+ Class cls = (((List) value).size() > 0) ? ((List) value).get(0).getClass() : double.class;
+ value = Convert.toPrimitiveArray(value, cls);
+ //value = Convert.toDouble(value);
+ }
+ dm.setAttribute(pathImage, key, value);
+ }
+ }
+ } else if (val.getClass().isArray()) {
+ dm.createDataset(pathRoot + id, Double.class, new int[]{depth, Array.getLength(val)});
+ } else {
+ dm.createDataset(pathRoot + id, val.getClass(), new int[]{depth});
+ }
+ }
+
+ //Add metadata
+ dm.setAttribute(pathRoot, "Camera", camera);
+ dm.setAttribute(pathRoot, "Images", depth);
+ dm.setAttribute(pathRoot, "Interval", -1);
+ dm.setAttribute(pathRoot, "Type", type);
+ if (type.equals(ELECTRONS_TYPE)) {
+ dm.setAttribute(pathRoot, "Screen", String.valueOf(valueScreen.getLabel().getText()));
+ dm.setAttribute(pathRoot, "Filter", String.valueOf(valueFilter.getLabel().getText()));
+ }
+
+ //Save data
+ for (int index = 0; index < depth; index++) {
+ StreamValue streamValue = images.get(index);
+ dm.setItem(pathImage, streamValue.getValue("image"), new long[]{index, 0, 0}, new int[]{1, height, width});
+ dm.setItem(pathPid, streamValue.getPulseId(), index);
+ dm.setItem(pathTimestampStr, Chrono.getTimeStr(streamValue.getTimestamp(), "YYYY-MM-dd HH:mm:ss.SSS"), index);
+
+ for (String id : streamValue.getIdentifiers()) {
+ Object val = streamValue.getValue(id);
+ if (id.equals("image")) {
+ } else if (id.equals("processing_parameters")) {
+ } else if (val.getClass().isArray()) {
+ dm.setItem(pathRoot + id, val, index);
+ } else {
+ dm.setItem(pathRoot + id, val, index);
+ }
+ }
+ }
+ getContext().getDataManager().closeOutput();
+ }
+
+ StandardDialog calibrationDialolg;
+
+ void calibrate() throws Exception {
+ if (server != null) {
+ server.resetRoi();
+ calibrationDialolg = (StandardDialog) getContext().getClassByName("CameraCalibrationDialog").getConstructors()[0].newInstance(new Object[]{getTopLevel(), server.getCurrentCamera(), renderer});
+ SwingUtils.centerComponent(getTopLevel(), calibrationDialolg);
+ calibrationDialolg.setVisible(true);
+ calibrationDialolg.setListener(new StandardDialogListener() {
+ @Override
+ public void onWindowOpened(StandardDialog dlg) {
+ }
+
+ @Override
+ public void onWindowClosed(StandardDialog dlg, boolean accepted) {
+ if (accepted) {
+ //comboCamerasActionPerformed(null);
+ }
+ }
+ });
+ }
+ }
+
+ StandardDialog dataTableDialog;
+ DefaultTableModel dataTableModel;
+ JTable dataTable;
+
+ void showStreamData() {
+ dataTableModel = null;
+ if (server != null) {
+
+ if ((dataTableDialog != null) && (dataTableDialog.isShowing())) {
+ SwingUtils.centerComponent(getTopLevel(), dataTableDialog);
+ dataTableDialog.requestFocus();
+ return;
+ }
+ dataTableModel = new DefaultTableModel(new Object[0][2], new String[]{"Name", "Value"}) {
+ public Class getColumnClass(int columnIndex) {
+ return String.class;
+ }
+
+ public boolean isCellEditable(int rowIndex, int columnIndex) {
+ return false;
+ }
+ };
+ updateStreamData();
+ StreamValue val = server.getStream().take();
+ dataTable = new JTable(dataTableModel);
+ dataTable.setSelectionMode(ListSelectionModel.SINGLE_INTERVAL_SELECTION);
+ dataTable.setCellSelectionEnabled(true);
+ dataTable.getTableHeader().setReorderingAllowed(false);
+ dataTable.getTableHeader().setResizingAllowed(true);
+ dataTableDialog = new StandardDialog(getTopLevel(), "Image Data", false);
+ dataTableDialog.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
+ JScrollPane scrollPane = new JScrollPane();
+ scrollPane.setViewportView(dataTable);
+ scrollPane.setPreferredSize(new Dimension(300, 400));
+ dataTableDialog.setContentPane(scrollPane);
+ dataTableDialog.pack();
+ dataTableDialog.setVisible(true);
+ dataTableDialog.addWindowListener(new WindowAdapter() {
+ @Override
+ public void windowClosing(WindowEvent e) {
+ dataTableModel = null;
+ }
+ });
+ dataTable.addMouseListener(new MouseAdapter() {
+ @Override
+ public void mouseClicked(MouseEvent e) {
+ try {
+ int row = dataTable.getSelectedRow();
+ int col = dataTable.getSelectedColumn();
+ dataTable.setToolTipText(null);
+ if (row > 1) {
+ String id = String.valueOf(dataTable.getModel().getValueAt(row, 0));
+ String locator = String.valueOf(dataTable.getModel().getValueAt(0, 1));
+ String channelId = locator + " " + id;
+ dataTable.setToolTipText(channelId);
+ if ((e.getClickCount() == 2) && (!e.isPopupTrigger())) {
+ if (col == 0) {
+ SwingUtils.showMessage(dataTableDialog, "Channel Identifier", "Copied to clipboard: " + channelId);
+ Clipboard clipboard = Toolkit.getDefaultToolkit().getSystemClipboard();
+ clipboard.setContents(new StringSelection(channelId), (Clipboard clipboard1, Transferable contents) -> {
+ });
+ } else {
+ Object obj = getCurrentFrame().cache.getValue(id);
+ if (id.equals("image")) {
+ } else if (id.equals("processing_parameters")) {
+ Map pars = getProcessingParameters(getCurrentFrame().cache);
+ StringBuilder sb = new StringBuilder();
+ for (String key : pars.keySet()) {
+ sb.append(key).append(" = ").append(Str.toString(pars.get(key), 10)).append("\n");
+ }
+ SwingUtils.showMessage(dataTableDialog, "Processing Parameters", sb.toString());
+ } else if ((obj != null) && (obj.getClass().isArray() || (obj instanceof Number))) {
+ DeviceValueChart chart = new DeviceValueChart();
+ Device dev = null;
+ if (obj.getClass().isArray()) {
+ dev = new ReadableRegisterArray(new ReadableArray() {
+ @Override
+ public Object read() throws IOException, InterruptedException {
+ return Convert.toDouble(getCurrentFrame().cache.getValue(id));
+ }
+
+ @Override
+ public int getSize() {
+ return Array.getLength(getCurrentFrame().cache.getValue(id));
+ }
+ });
+ } else {
+ dev = new ReadableRegisterNumber(new ReadableNumber() {
+ @Override
+ public Object read() throws IOException, InterruptedException {
+ return Convert.toDouble(getCurrentFrame().cache.getValue(id));
+ }
+ });
+ }
+ dev.setPolling(1000);
+ chart.setDevice(dev);
+ JDialog dlg = SwingUtils.showDialog(dataTableDialog, cameraName + " " + id, null, chart);
+ //TODO:
+ //PlotBase plot = chart.getPlot();
+ //if (plot!=null){
+ // plot.setPlotBackgroundColor(Color.BLACK);
+ //}
+ }
+ }
+ }
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }
+ });
+ SwingUtils.centerComponent(getTopLevel(), dataTableDialog);
+ updateStreamData();
+ }
+ }
+
+ volatile boolean updatingStreamData = false;
+
+ void updateStreamData() {
+ if ((dataTableDialog == null) || !dataTableDialog.isShowing() || updatingStreamData) {
+ return;
+ }
+ updatingStreamData = true;
+ SwingUtilities.invokeLater(() -> {
+ updatingStreamData = false;
+ if ((dataTableModel != null) && (server != null)) {
+ StreamValue value = server.getValue();
+ Frame frame = getCurrentFrame();
+ int[] sel_rows = (dataTable == null) ? null : dataTable.getSelectedRows();
+ int[] sel_cols = (dataTable == null) ? null : dataTable.getSelectedColumns();
+ List ids = (value == null) ? new ArrayList<>() : new ArrayList(value.getIdentifiers());
+ if (ids.size() + 4 != dataTableModel.getRowCount()) {
+ dataTableModel.setNumRows(0);
+ try {
+ dataTableModel.addRow(new Object[]{"Locator", server.getUrl() + "/" + ((value == null) ? instanceName : server.getCurrentInstance())});
+ } catch (Exception ex) {
+ dataTableModel.addRow(new Object[]{"Locator", ex.getMessage()});
+ }
+ try {
+ dataTableModel.addRow(new Object[]{"Stream", server.getStreamAddress()});
+ } catch (Exception ex) {
+ dataTableModel.addRow(new Object[]{"Stream", ex.getMessage()});
+ }
+ dataTableModel.addRow(new Object[]{"PID", ""});
+ dataTableModel.addRow(new Object[]{"Timestamp", ""});
+ Collections.sort(ids);
+ for (String id : ids) {
+ dataTableModel.addRow(new Object[]{id, ""});
+ }
+ }
+
+ if ((frame != null) && (frame.cache != null)) {
+ dataTableModel.setValueAt(frame.cache.getPulseId(), 2, 1); //PID
+ dataTableModel.setValueAt(frame.cache.getTimestamp(), 3, 1); //Timestamp
+ for (int i = 4; i < dataTableModel.getRowCount(); i++) {
+ String id = String.valueOf(dataTableModel.getValueAt(i, 0));
+ //Object obj = server.getValue(id);
+ Object obj = frame.cache.getValue(id);
+ if (obj != null) {
+ if (obj.getClass().isArray()) {
+ obj = obj.getClass().getComponentType().getSimpleName() + "[" + Array.getLength(obj) + "]";
+ } else if (obj instanceof Double) {
+ obj = Convert.roundDouble((Double) obj, 1);
+ } else if (obj instanceof Float) {
+ obj = Convert.roundDouble((Float) obj, 1);
+ }
+ }
+ dataTableModel.setValueAt(String.valueOf(obj), i, 1);
+ }
+ }
+ if ((sel_rows != null) && (sel_rows.length > 0)) {
+ //dataTable.setRowSelectionInterval((Integer)Arr.getMin(sel_rows), (Integer)Arr.getMax(sel_rows));
+ dataTable.setRowSelectionInterval(sel_rows[0], sel_rows[sel_rows.length - 1]);
+ }
+ if ((sel_cols != null) && (sel_cols.length > 0)) {
+ //dataTable.setColumnSelectionInterval((Integer)Arr.getMin(sel_cols), (Integer)Arr.getMax(sel_cols));
+ dataTable.setColumnSelectionInterval(sel_cols[0], sel_cols[sel_cols.length - 1]);
+ }
+ }
+ });
+ }
+
+ ImageIcon getIcon(String name) {
+ ImageIcon ret = null;
+ try {
+ //Path path = Paths.get(getClass().getProtectionDomain().getCodeSource().getLocation().getPath(),"resources", name + ".png");
+ String dir = getClass().getProtectionDomain().getCodeSource().getLocation().getPath() + "resources/";
+ if (new File(dir + name + ".png").exists()) {
+ ret = new javax.swing.ImageIcon(dir + name + ".png");
+ } else {
+ ret = new ImageIcon(ch.psi.pshell.ui.App.class.getResource("/ch/psi/pshell/ui/" + name + ".png"));
+ if (MainFrame.isDark()) {
+ try {
+ ret = new ImageIcon(ch.psi.pshell.ui.App.class.getResource("/ch/psi/pshell/ui/dark/" + name + ".png"));
+ } catch (Exception e) {
+ }
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ return ret;
+ }
+
+ String getIconName(JButton button) {
+ String ret = button.getIcon().toString();
+ if (ret.indexOf(".") > 0) {
+ ret = ret.substring(0, ret.indexOf("."));
+ }
+ return ret;
+ }
+
+ void setPaused(boolean paused){
+ removePauseOverlay();
+ if (camera != null) {
+ synchronized (imageBuffer) {
+ if (paused) {
+ renderer.pause();
+ panelCameraSelection.setVisible(false);
+ pauseSelection.setVisible(true);
+ if (imageBuffer.size() > 0) {
+ pauseSelection.setEnabled(true);
+ pauseSelection.setMaxValue(imageBuffer.size());
+ pauseSelection.setValue(imageBuffer.size());
+ updatePause();
+ } else {
+ pauseSelection.setEnabled(false);
+ pauseSelection.setMaxValue(1);
+ pauseSelection.setValue(1);
+ }
+ } else {
+ imageBuffer.clear();
+ renderer.resume();
+ //renderer.clear();
+ pauseSelection.setVisible(false);
+ panelCameraSelection.setVisible(true);
+ }
+ }
+ updateStreamData();
+ }
+ }
+
+ boolean isPaused(){
+ return renderer.isPaused();
+ }
+
+ ////////
+ @SuppressWarnings("unchecked")
+ // //GEN-BEGIN:initComponents
+ private void initComponents() {
+
+ buttonGroup1 = new javax.swing.ButtonGroup();
+ buttonGroup2 = new javax.swing.ButtonGroup();
+ buttonGroup3 = new javax.swing.ButtonGroup();
+ buttonGroup4 = new javax.swing.ButtonGroup();
+ jProgressBar1 = new javax.swing.JProgressBar();
+ sidePanel = new javax.swing.JPanel();
+ jPanel3 = new javax.swing.JPanel();
+ buttonZoomFit = new javax.swing.JRadioButton();
+ buttonZoomStretch = new javax.swing.JRadioButton();
+ buttonZoomNormal = new javax.swing.JRadioButton();
+ buttonZoom025 = new javax.swing.JRadioButton();
+ buttonZoom05 = new javax.swing.JRadioButton();
+ buttonZoom2 = new javax.swing.JRadioButton();
+ jPanel2 = new javax.swing.JPanel();
+ checkHistogram = new javax.swing.JCheckBox();
+ comboColormap = new javax.swing.JComboBox();
+ jLabel3 = new javax.swing.JLabel();
+ jLabel4 = new javax.swing.JLabel();
+ buttonFullRange = new javax.swing.JRadioButton();
+ buttonManual = new javax.swing.JRadioButton();
+ buttonAutomatic = new javax.swing.JRadioButton();
+ labelMin = new javax.swing.JLabel();
+ spinnerMin = new javax.swing.JSpinner();
+ spinnerMax = new javax.swing.JSpinner();
+ labelMax = new javax.swing.JLabel();
+ btFixColormapRange = new javax.swing.JButton();
+ jPanel5 = new javax.swing.JPanel();
+ buttonServer = new javax.swing.JRadioButton();
+ buttonDirect = new javax.swing.JRadioButton();
+ textState = new javax.swing.JTextField();
+ filler1 = new javax.swing.Box.Filler(new java.awt.Dimension(0, 0), new java.awt.Dimension(0, 0), new java.awt.Dimension(0, 32767));
+ panelScreen = new javax.swing.JPanel();
+ valueScreen = new ch.psi.pshell.swing.DeviceValuePanel();
+ comboScreen = new javax.swing.JComboBox();
+ panelFilter = new javax.swing.JPanel();
+ valueFilter = new ch.psi.pshell.swing.DeviceValuePanel();
+ comboFilter = new javax.swing.JComboBox();
+ panelScreen2 = new javax.swing.JPanel();
+ checkThreshold = new javax.swing.JCheckBox();
+ spinnerThreshold = new javax.swing.JSpinner();
+ checkBackground = new javax.swing.JCheckBox();
+ checkGoodRegion = new javax.swing.JCheckBox();
+ spinnerGrScale = new javax.swing.JSpinner();
+ spinnerGrThreshold = new javax.swing.JSpinner();
+ labelGrThreshold = new javax.swing.JLabel();
+ labelGrScale = new javax.swing.JLabel();
+ panelSlicing = new javax.swing.JPanel();
+ checkSlicing = new javax.swing.JCheckBox();
+ labelSlScale = new javax.swing.JLabel();
+ spinnerSlScale = new javax.swing.JSpinner();
+ labelSlNumber = new javax.swing.JLabel();
+ spinnerSlNumber = new javax.swing.JSpinner();
+ labelSlOrientation = new javax.swing.JLabel();
+ spinnerSlOrientation = new javax.swing.JSpinner();
+ checkRotation = new javax.swing.JCheckBox();
+ spinnerRotationAngle = new javax.swing.JSpinner();
+ spinnerRotationOrder = new javax.swing.JSpinner();
+ labelOrder = new javax.swing.JLabel();
+ labelMode = new javax.swing.JLabel();
+ spinnerRotationMode = new javax.swing.JSpinner();
+ labelAngle = new javax.swing.JLabel();
+ labelConstant = new javax.swing.JLabel();
+ spinnerRotationConstant = new javax.swing.JSpinner();
+ topPanel = new javax.swing.JPanel();
+ toolBar = new javax.swing.JToolBar();
+ buttonSidePanel = new javax.swing.JToggleButton();
+ buttonStreamData = new javax.swing.JButton();
+ buttonSave = new javax.swing.JToggleButton();
+ buttonGrabBackground = new javax.swing.JButton();
+ buttonPause = new javax.swing.JToggleButton();
+ jSeparator6 = new javax.swing.JToolBar.Separator();
+ buttonMarker = new javax.swing.JToggleButton();
+ buttonProfile = new javax.swing.JToggleButton();
+ buttonFit = new javax.swing.JToggleButton();
+ buttonReticle = new javax.swing.JToggleButton();
+ buttonScale = new javax.swing.JToggleButton();
+ buttonTitle = new javax.swing.JToggleButton();
+ pauseSelection = new ch.psi.pshell.swing.ValueSelection();
+ panelCameraSelection = new javax.swing.JPanel();
+ jLabel1 = new javax.swing.JLabel();
+ comboCameras = new javax.swing.JComboBox();
+ jLabel5 = new javax.swing.JLabel();
+ comboType = new javax.swing.JComboBox();
+ renderer = new ch.psi.pshell.imaging.Renderer();
+
+ setPreferredSize(new java.awt.Dimension(873, 600));
+
+ jPanel3.setBorder(javax.swing.BorderFactory.createTitledBorder("Zoom"));
+
+ buttonGroup1.add(buttonZoomFit);
+ buttonZoomFit.setText("Fit");
+ buttonZoomFit.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonZoomFitActionPerformed(evt);
+ }
+ });
+
+ buttonGroup1.add(buttonZoomStretch);
+ buttonZoomStretch.setText("Stretch");
+ buttonZoomStretch.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonZoomStretchActionPerformed(evt);
+ }
+ });
+
+ buttonGroup1.add(buttonZoomNormal);
+ buttonZoomNormal.setText("Normal");
+ buttonZoomNormal.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonZoomNormalActionPerformed(evt);
+ }
+ });
+
+ buttonGroup1.add(buttonZoom025);
+ buttonZoom025.setText("1/4");
+ buttonZoom025.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonZoom025ActionPerformed(evt);
+ }
+ });
+
+ buttonGroup1.add(buttonZoom05);
+ buttonZoom05.setText("1/2");
+ buttonZoom05.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonZoom05ActionPerformed(evt);
+ }
+ });
+
+ buttonGroup1.add(buttonZoom2);
+ buttonZoom2.setText("2");
+ buttonZoom2.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonZoom2ActionPerformed(evt);
+ }
+ });
+
+ javax.swing.GroupLayout jPanel3Layout = new javax.swing.GroupLayout(jPanel3);
+ jPanel3.setLayout(jPanel3Layout);
+ jPanel3Layout.setHorizontalGroup(
+ jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(jPanel3Layout.createSequentialGroup()
+ .addContainerGap()
+ .addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(buttonZoomFit)
+ .addComponent(buttonZoomNormal)
+ .addComponent(buttonZoomStretch))
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(buttonZoom025)
+ .addComponent(buttonZoom05)
+ .addComponent(buttonZoom2))
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ );
+ jPanel3Layout.setVerticalGroup(
+ jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(jPanel3Layout.createSequentialGroup()
+ .addGap(4, 4, 4)
+ .addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(buttonZoomNormal)
+ .addComponent(buttonZoom025))
+ .addGap(0, 0, 0)
+ .addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(buttonZoomFit)
+ .addComponent(buttonZoom05))
+ .addGap(0, 0, 0)
+ .addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(buttonZoomStretch)
+ .addComponent(buttonZoom2))
+ .addContainerGap())
+ );
+
+ jPanel2.setBorder(javax.swing.BorderFactory.createTitledBorder("Colormap"));
+
+ checkHistogram.setText("Histogram");
+ checkHistogram.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ checkHistogramActionPerformed(evt);
+ }
+ });
+
+ comboColormap.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ onChangeColormap(evt);
+ }
+ });
+
+ jLabel3.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ jLabel3.setText("Type:");
+
+ jLabel4.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ jLabel4.setText("Range:");
+
+ buttonGroup3.add(buttonFullRange);
+ buttonFullRange.setText("Full");
+ buttonFullRange.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ onChangeColormap(evt);
+ }
+ });
+
+ buttonGroup3.add(buttonManual);
+ buttonManual.setText("Manual");
+ buttonManual.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ onChangeColormap(evt);
+ }
+ });
+
+ buttonGroup3.add(buttonAutomatic);
+ buttonAutomatic.setText("Automatic");
+ buttonAutomatic.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ onChangeColormap(evt);
+ }
+ });
+
+ labelMin.setText("Min:");
+
+ spinnerMin.setModel(new javax.swing.SpinnerNumberModel(0, 0, 65535, 1));
+ spinnerMin.setEnabled(false);
+ spinnerMin.setPreferredSize(new java.awt.Dimension(77, 20));
+ spinnerMin.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ onChangeColormapRange(evt);
+ }
+ });
+
+ spinnerMax.setModel(new javax.swing.SpinnerNumberModel(255, 0, 65535, 1));
+ spinnerMax.setEnabled(false);
+ spinnerMax.setPreferredSize(new java.awt.Dimension(77, 20));
+ spinnerMax.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ onChangeColormapRange(evt);
+ }
+ });
+
+ labelMax.setText("Max:");
+
+ btFixColormapRange.setText("Fix");
+ btFixColormapRange.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ btFixColormapRangeActionPerformed(evt);
+ }
+ });
+
+ javax.swing.GroupLayout jPanel2Layout = new javax.swing.GroupLayout(jPanel2);
+ jPanel2.setLayout(jPanel2Layout);
+ jPanel2Layout.setHorizontalGroup(
+ jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(jPanel2Layout.createSequentialGroup()
+ .addGap(4, 4, 4)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(jLabel3)
+ .addComponent(jLabel4))
+ .addGap(4, 4, 4)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(buttonAutomatic)
+ .addComponent(buttonFullRange)
+ .addComponent(buttonManual)
+ .addComponent(comboColormap, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel2Layout.createSequentialGroup()
+ .addComponent(labelMax)
+ .addGap(2, 2, 2)
+ .addComponent(spinnerMax, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addComponent(checkHistogram, javax.swing.GroupLayout.Alignment.TRAILING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel2Layout.createSequentialGroup()
+ .addComponent(labelMin)
+ .addGap(2, 2, 2)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false)
+ .addComponent(btFixColormapRange, javax.swing.GroupLayout.Alignment.TRAILING)
+ .addComponent(spinnerMin, javax.swing.GroupLayout.Alignment.TRAILING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))))
+ .addContainerGap())
+ );
+
+ jPanel2Layout.linkSize(javax.swing.SwingConstants.HORIZONTAL, new java.awt.Component[] {btFixColormapRange, spinnerMax, spinnerMin});
+
+ jPanel2Layout.linkSize(javax.swing.SwingConstants.HORIZONTAL, new java.awt.Component[] {jLabel3, jLabel4});
+
+ jPanel2Layout.setVerticalGroup(
+ jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel2Layout.createSequentialGroup()
+ .addGap(4, 4, 4)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(comboColormap, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(jLabel3)
+ .addComponent(checkHistogram))
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(buttonAutomatic)
+ .addComponent(jLabel4)
+ .addComponent(btFixColormapRange, javax.swing.GroupLayout.PREFERRED_SIZE, 26, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addGap(0, 0, 0)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(labelMin)
+ .addComponent(spinnerMin, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(buttonFullRange))
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(buttonManual)
+ .addComponent(labelMax)
+ .addComponent(spinnerMax, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addContainerGap())
+ );
+
+ jPanel5.setBorder(javax.swing.BorderFactory.createTitledBorder("Source"));
+
+ buttonGroup4.add(buttonServer);
+ buttonServer.setSelected(true);
+ buttonServer.setText("Server");
+ buttonServer.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonServerActionPerformed(evt);
+ }
+ });
+
+ buttonGroup4.add(buttonDirect);
+ buttonDirect.setText("Direct");
+ buttonDirect.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonDirectActionPerformed(evt);
+ }
+ });
+
+ textState.setEditable(false);
+ textState.setHorizontalAlignment(javax.swing.JTextField.CENTER);
+ textState.setDisabledTextColor(new java.awt.Color(0, 0, 0));
+ textState.setEnabled(false);
+
+ javax.swing.GroupLayout jPanel5Layout = new javax.swing.GroupLayout(jPanel5);
+ jPanel5.setLayout(jPanel5Layout);
+ jPanel5Layout.setHorizontalGroup(
+ jPanel5Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(jPanel5Layout.createSequentialGroup()
+ .addContainerGap()
+ .addComponent(buttonServer)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(buttonDirect)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(textState, javax.swing.GroupLayout.PREFERRED_SIZE, 80, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addContainerGap())
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel5Layout.createSequentialGroup()
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(filler1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addGap(56, 56, 56))
+ );
+ jPanel5Layout.setVerticalGroup(
+ jPanel5Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(jPanel5Layout.createSequentialGroup()
+ .addGap(4, 4, 4)
+ .addGroup(jPanel5Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(jPanel5Layout.createSequentialGroup()
+ .addComponent(textState, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(filler1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addGroup(jPanel5Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(buttonServer)
+ .addComponent(buttonDirect)))
+ .addContainerGap())
+ );
+
+ panelScreen.setBorder(javax.swing.BorderFactory.createTitledBorder("Screen"));
+
+ comboScreen.setEnabled(false);
+ comboScreen.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ comboScreenActionPerformed(evt);
+ }
+ });
+
+ javax.swing.GroupLayout panelScreenLayout = new javax.swing.GroupLayout(panelScreen);
+ panelScreen.setLayout(panelScreenLayout);
+ panelScreenLayout.setHorizontalGroup(
+ panelScreenLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelScreenLayout.createSequentialGroup()
+ .addContainerGap()
+ .addGroup(panelScreenLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(valueScreen, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(comboScreen, 0, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ .addContainerGap())
+ );
+ panelScreenLayout.setVerticalGroup(
+ panelScreenLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelScreenLayout.createSequentialGroup()
+ .addGap(4, 4, 4)
+ .addComponent(comboScreen, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(valueScreen, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addContainerGap())
+ );
+
+ panelFilter.setBorder(javax.swing.BorderFactory.createTitledBorder("Filter"));
+
+ comboFilter.setEnabled(false);
+ comboFilter.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ comboFilterActionPerformed(evt);
+ }
+ });
+
+ javax.swing.GroupLayout panelFilterLayout = new javax.swing.GroupLayout(panelFilter);
+ panelFilter.setLayout(panelFilterLayout);
+ panelFilterLayout.setHorizontalGroup(
+ panelFilterLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelFilterLayout.createSequentialGroup()
+ .addContainerGap()
+ .addGroup(panelFilterLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(valueFilter, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(comboFilter, 0, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ .addContainerGap())
+ );
+ panelFilterLayout.setVerticalGroup(
+ panelFilterLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelFilterLayout.createSequentialGroup()
+ .addGap(4, 4, 4)
+ .addComponent(comboFilter, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(valueFilter, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ );
+
+ panelScreen2.setBorder(javax.swing.BorderFactory.createTitledBorder("Pipeline"));
+
+ checkThreshold.setText("Threshold");
+ checkThreshold.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ checkThresholdActionPerformed(evt);
+ }
+ });
+
+ spinnerThreshold.setModel(new javax.swing.SpinnerNumberModel(0.0d, 0.0d, 99999.0d, 1.0d));
+ spinnerThreshold.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerThresholdonChange(evt);
+ }
+ });
+
+ checkBackground.setText("Subtract Background");
+ checkBackground.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ checkBackgroundActionPerformed(evt);
+ }
+ });
+
+ checkGoodRegion.setText("Good Region");
+ checkGoodRegion.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ checkGoodRegionActionPerformed(evt);
+ }
+ });
+
+ spinnerGrScale.setModel(new javax.swing.SpinnerNumberModel(3.0d, 0.01d, 99999.0d, 1.0d));
+ spinnerGrScale.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerGrThresholdonChange(evt);
+ }
+ });
+
+ spinnerGrThreshold.setModel(new javax.swing.SpinnerNumberModel(0.5d, 0.04d, 1.0d, 0.1d));
+ spinnerGrThreshold.setPreferredSize(new java.awt.Dimension(92, 20));
+ spinnerGrThreshold.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerGrThresholdonChange(evt);
+ }
+ });
+
+ labelGrThreshold.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelGrThreshold.setText("Threshold:");
+
+ labelGrScale.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelGrScale.setText("Scale:");
+
+ checkSlicing.setText("Slicing");
+ checkSlicing.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ checkSlicingActionPerformed(evt);
+ }
+ });
+
+ labelSlScale.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelSlScale.setText("Scale:");
+
+ spinnerSlScale.setModel(new javax.swing.SpinnerNumberModel(3.0d, 0.01d, 99999.0d, 1.0d));
+ spinnerSlScale.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerSlicingChange(evt);
+ }
+ });
+
+ labelSlNumber.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelSlNumber.setText("Slices:");
+
+ spinnerSlNumber.setModel(new javax.swing.SpinnerNumberModel(2, 0, 1000, 1));
+ spinnerSlNumber.setPreferredSize(new java.awt.Dimension(92, 20));
+ spinnerSlNumber.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerSlicingChange(evt);
+ }
+ });
+
+ labelSlOrientation.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelSlOrientation.setText("Orientation:");
+
+ spinnerSlOrientation.setModel(new javax.swing.SpinnerListModel(new String[] {"vertical", "horizontal"}));
+ spinnerSlOrientation.setPreferredSize(new java.awt.Dimension(92, 20));
+ spinnerSlOrientation.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerSlicingChange(evt);
+ }
+ });
+
+ javax.swing.GroupLayout panelSlicingLayout = new javax.swing.GroupLayout(panelSlicing);
+ panelSlicing.setLayout(panelSlicingLayout);
+ panelSlicingLayout.setHorizontalGroup(
+ panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelSlicingLayout.createSequentialGroup()
+ .addContainerGap()
+ .addGroup(panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelSlicingLayout.createSequentialGroup()
+ .addComponent(checkSlicing)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addGroup(panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelSlicingLayout.createSequentialGroup()
+ .addComponent(labelSlNumber)
+ .addGap(2, 2, 2)
+ .addComponent(spinnerSlNumber, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelSlicingLayout.createSequentialGroup()
+ .addComponent(labelSlScale)
+ .addGap(2, 2, 2)
+ .addComponent(spinnerSlScale, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))))
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelSlicingLayout.createSequentialGroup()
+ .addGap(0, 0, Short.MAX_VALUE)
+ .addComponent(labelSlOrientation)
+ .addGap(2, 2, 2)
+ .addComponent(spinnerSlOrientation, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)))
+ .addContainerGap())
+ );
+
+ panelSlicingLayout.linkSize(javax.swing.SwingConstants.HORIZONTAL, new java.awt.Component[] {spinnerSlNumber, spinnerSlOrientation, spinnerSlScale});
+
+ panelSlicingLayout.setVerticalGroup(
+ panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelSlicingLayout.createSequentialGroup()
+ .addGroup(panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(checkSlicing)
+ .addGroup(panelSlicingLayout.createSequentialGroup()
+ .addGroup(panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerSlNumber, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelSlNumber))
+ .addGap(0, 0, 0)
+ .addGroup(panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerSlScale, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelSlScale))))
+ .addGap(0, 0, 0)
+ .addGroup(panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerSlOrientation, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelSlOrientation)))
+ );
+
+ panelSlicingLayout.linkSize(javax.swing.SwingConstants.VERTICAL, new java.awt.Component[] {spinnerSlNumber, spinnerSlOrientation, spinnerSlScale});
+
+ checkRotation.setText("Rotation");
+ checkRotation.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ checkRotationActionPerformed(evt);
+ }
+ });
+
+ spinnerRotationAngle.setModel(new javax.swing.SpinnerNumberModel(0.0d, -360.0d, 360.0d, 1.0d));
+ spinnerRotationAngle.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerRotationAngleStateChanged(evt);
+ }
+ });
+
+ spinnerRotationOrder.setModel(new javax.swing.SpinnerNumberModel(1, 1, 5, 1));
+ spinnerRotationOrder.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerRotationAngleStateChanged(evt);
+ }
+ });
+
+ labelOrder.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelOrder.setText("Order:");
+
+ labelMode.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelMode.setText("Mode:");
+
+ spinnerRotationMode.setModel(new javax.swing.SpinnerListModel(new String[] {"constant", "reflect", "nearest", "mirror", "wrap"}));
+ spinnerRotationMode.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerRotationAngleStateChanged(evt);
+ }
+ });
+
+ labelAngle.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelAngle.setText("Angle:");
+
+ labelConstant.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelConstant.setText("Constant:");
+
+ spinnerRotationConstant.setModel(new javax.swing.SpinnerNumberModel(0, 0, 99999, 1));
+ spinnerRotationConstant.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerRotationAngleStateChanged(evt);
+ }
+ });
+
+ javax.swing.GroupLayout panelScreen2Layout = new javax.swing.GroupLayout(panelScreen2);
+ panelScreen2.setLayout(panelScreen2Layout);
+ panelScreen2Layout.setHorizontalGroup(
+ panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelScreen2Layout.createSequentialGroup()
+ .addContainerGap()
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelScreen2Layout.createSequentialGroup()
+ .addComponent(checkGoodRegion)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(labelOrder)
+ .addComponent(labelGrScale)
+ .addComponent(labelMode)))
+ .addGroup(panelScreen2Layout.createSequentialGroup()
+ .addComponent(checkThreshold)
+ .addGap(0, 0, Short.MAX_VALUE))
+ .addGroup(panelScreen2Layout.createSequentialGroup()
+ .addComponent(checkRotation)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(labelAngle))
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelScreen2Layout.createSequentialGroup()
+ .addGap(0, 0, Short.MAX_VALUE)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(labelGrThreshold, javax.swing.GroupLayout.Alignment.TRAILING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelScreen2Layout.createSequentialGroup()
+ .addComponent(labelConstant)
+ .addGap(3, 3, 3)))))
+ .addGap(2, 2, 2)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false)
+ .addComponent(spinnerGrThreshold, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(spinnerGrScale)
+ .addComponent(spinnerThreshold)
+ .addComponent(spinnerRotationOrder)
+ .addComponent(spinnerRotationMode)
+ .addComponent(spinnerRotationAngle)
+ .addComponent(spinnerRotationConstant))
+ .addContainerGap())
+ .addComponent(panelSlicing, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addGroup(panelScreen2Layout.createSequentialGroup()
+ .addGap(6, 6, 6)
+ .addComponent(checkBackground)
+ .addGap(106, 106, 106))
+ );
+
+ panelScreen2Layout.linkSize(javax.swing.SwingConstants.HORIZONTAL, new java.awt.Component[] {spinnerGrScale, spinnerGrThreshold, spinnerRotationAngle, spinnerRotationConstant, spinnerRotationMode, spinnerRotationOrder, spinnerThreshold});
+
+ panelScreen2Layout.setVerticalGroup(
+ panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelScreen2Layout.createSequentialGroup()
+ .addContainerGap()
+ .addComponent(checkBackground)
+ .addGap(2, 2, 2)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(checkThreshold)
+ .addComponent(spinnerThreshold, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addGap(2, 2, 2)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(checkRotation)
+ .addComponent(spinnerRotationAngle, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelAngle))
+ .addGap(0, 0, 0)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerRotationOrder, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelOrder))
+ .addGap(0, 0, 0)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerRotationMode, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelMode))
+ .addGap(0, 0, 0)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerRotationConstant, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelConstant))
+ .addGap(2, 2, 2)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(checkGoodRegion)
+ .addComponent(spinnerGrScale, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelGrScale))
+ .addGap(0, 0, 0)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerGrThreshold, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelGrThreshold))
+ .addGap(2, 2, 2)
+ .addComponent(panelSlicing, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addContainerGap())
+ );
+
+ panelScreen2Layout.linkSize(javax.swing.SwingConstants.VERTICAL, new java.awt.Component[] {spinnerGrScale, spinnerGrThreshold, spinnerRotationAngle, spinnerRotationConstant, spinnerRotationMode, spinnerRotationOrder, spinnerThreshold});
+
+ javax.swing.GroupLayout sidePanelLayout = new javax.swing.GroupLayout(sidePanel);
+ sidePanel.setLayout(sidePanelLayout);
+ sidePanelLayout.setHorizontalGroup(
+ sidePanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(sidePanelLayout.createSequentialGroup()
+ .addContainerGap()
+ .addGroup(sidePanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING, false)
+ .addComponent(jPanel5, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(jPanel3, javax.swing.GroupLayout.Alignment.LEADING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(jPanel2, javax.swing.GroupLayout.Alignment.LEADING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(panelScreen2, javax.swing.GroupLayout.Alignment.LEADING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(panelScreen, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(panelFilter, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ );
+ sidePanelLayout.setVerticalGroup(
+ sidePanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(sidePanelLayout.createSequentialGroup()
+ .addGap(0, 0, 0)
+ .addComponent(jPanel5, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(panelScreen2, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(jPanel3, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(jPanel2, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(panelScreen, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(panelFilter, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ );
+
+ toolBar.setFloatable(false);
+ toolBar.setRollover(true);
+
+ buttonSidePanel.setIcon(getIcon("List"));
+ buttonSidePanel.setSelected(true);
+ buttonSidePanel.setText(" ");
+ buttonSidePanel.setToolTipText("Show Side Panel");
+ buttonSidePanel.setFocusable(false);
+ buttonSidePanel.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonSidePanel.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonSidePanelActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonSidePanel);
+
+ buttonStreamData.setIcon(getIcon("Details"));
+ buttonStreamData.setText(" ");
+ buttonStreamData.setToolTipText("Show Data Window");
+ buttonStreamData.setFocusable(false);
+ buttonStreamData.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonStreamData.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonStreamDataActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonStreamData);
+
+ buttonSave.setIcon(getIcon("Save"));
+ buttonSave.setText(" ");
+ buttonSave.setToolTipText("Save Snapshot");
+ buttonSave.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonSave.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonSaveActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonSave);
+
+ buttonGrabBackground.setIcon(getIcon("Background"));
+ buttonGrabBackground.setText(" ");
+ buttonGrabBackground.setToolTipText("Grab Background");
+ buttonGrabBackground.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonGrabBackground.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonGrabBackgroundActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonGrabBackground);
+
+ buttonPause.setIcon(getIcon("Pause"));
+ buttonPause.setText(" ");
+ buttonPause.setToolTipText("Pause");
+ buttonPause.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonPause.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonPauseActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonPause);
+
+ jSeparator6.setMaximumSize(new java.awt.Dimension(20, 32767));
+ jSeparator6.setPreferredSize(new java.awt.Dimension(20, 0));
+ jSeparator6.setRequestFocusEnabled(false);
+ toolBar.add(jSeparator6);
+
+ buttonMarker.setIcon(getIcon("Marker"));
+ buttonMarker.setText(" ");
+ buttonMarker.setToolTipText("Show Marker");
+ buttonMarker.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonMarker.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonMarkerActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonMarker);
+
+ buttonProfile.setIcon(getIcon("Profile"
+ + ""));
+ buttonProfile.setSelected(true);
+ buttonProfile.setText(" ");
+ buttonProfile.setToolTipText("Show Image Profile");
+ buttonProfile.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonProfile.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonProfileActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonProfile);
+
+ buttonFit.setIcon(getIcon("Fit"));
+ buttonFit.setSelected(true);
+ buttonFit.setText(" ");
+ buttonFit.setToolTipText("Show Fit");
+ buttonFit.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonFit.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonFitActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonFit);
+
+ buttonReticle.setIcon(getIcon("Reticule"));
+ buttonReticle.setSelected(true);
+ buttonReticle.setText(" ");
+ buttonReticle.setToolTipText("Show Reticle");
+ buttonReticle.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonReticle.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonReticleActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonReticle);
+
+ buttonScale.setIcon(getIcon("Scale"));
+ buttonScale.setSelected(true);
+ buttonScale.setText(" ");
+ buttonScale.setToolTipText("Show Colormap Scale");
+ buttonScale.setFocusable(false);
+ buttonScale.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonScale.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonScaleActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonScale);
+
+ buttonTitle.setIcon(getIcon("Title"));
+ buttonTitle.setSelected(true);
+ buttonTitle.setText(" ");
+ buttonTitle.setToolTipText("Show Camera Name");
+ buttonTitle.setFocusable(false);
+ buttonTitle.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonTitle.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonTitleActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonTitle);
+
+ pauseSelection.setDecimals(0);
+
+ jLabel1.setText("Camera:");
+
+ comboCameras.setFont(new java.awt.Font("Dialog", 1, 14)); // NOI18N
+ comboCameras.setMaximumRowCount(30);
+ comboCameras.setMinimumSize(new java.awt.Dimension(127, 27));
+ comboCameras.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ comboCamerasActionPerformed(evt);
+ }
+ });
+
+ jLabel5.setText("Type:");
+
+ comboType.setFont(new java.awt.Font("Dialog", 1, 14)); // NOI18N
+ comboType.setMaximumRowCount(30);
+ comboType.setModel(new javax.swing.DefaultComboBoxModel(new String[] { "All", "Laser", "Electrons", "Photonics" }));
+ comboType.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ comboTypeActionPerformed(evt);
+ }
+ });
+
+ javax.swing.GroupLayout panelCameraSelectionLayout = new javax.swing.GroupLayout(panelCameraSelection);
+ panelCameraSelection.setLayout(panelCameraSelectionLayout);
+ panelCameraSelectionLayout.setHorizontalGroup(
+ panelCameraSelectionLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelCameraSelectionLayout.createSequentialGroup()
+ .addContainerGap()
+ .addComponent(jLabel1)
+ .addGap(0, 0, 0)
+ .addComponent(comboCameras, javax.swing.GroupLayout.PREFERRED_SIZE, 222, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(jLabel5)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(comboType, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addGap(0, 0, 0))
+ );
+ panelCameraSelectionLayout.setVerticalGroup(
+ panelCameraSelectionLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelCameraSelectionLayout.createSequentialGroup()
+ .addGap(0, 0, 0)
+ .addGroup(panelCameraSelectionLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(comboType, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(jLabel5)
+ .addComponent(jLabel1)
+ .addComponent(comboCameras, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addGap(0, 0, 0))
+ );
+
+ javax.swing.GroupLayout topPanelLayout = new javax.swing.GroupLayout(topPanel);
+ topPanel.setLayout(topPanelLayout);
+ topPanelLayout.setHorizontalGroup(
+ topPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, topPanelLayout.createSequentialGroup()
+ .addComponent(toolBar, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addGap(18, 18, 18)
+ .addComponent(panelCameraSelection, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addGap(18, 18, 18)
+ .addComponent(pauseSelection, javax.swing.GroupLayout.PREFERRED_SIZE, 334, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addContainerGap())
+ );
+ topPanelLayout.setVerticalGroup(
+ topPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
+ .addGroup(topPanelLayout.createSequentialGroup()
+ .addGap(1, 1, 1)
+ .addGroup(topPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(pauseSelection, javax.swing.GroupLayout.PREFERRED_SIZE, 29, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(toolBar, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(panelCameraSelection, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)))
+ );
+
+ javax.swing.GroupLayout layout = new javax.swing.GroupLayout(this);
+ this.setLayout(layout);
+ layout.setHorizontalGroup(
+ layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(layout.createSequentialGroup()
+ .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
+ .addGroup(javax.swing.GroupLayout.Alignment.LEADING, layout.createSequentialGroup()
+ .addComponent(sidePanel, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(renderer, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ .addGroup(javax.swing.GroupLayout.Alignment.LEADING, layout.createSequentialGroup()
+ .addContainerGap()
+ .addComponent(topPanel, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)))
+ .addContainerGap())
+ );
+ layout.setVerticalGroup(
+ layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(layout.createSequentialGroup()
+ .addComponent(topPanel, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(sidePanel, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(renderer, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)))
+ );
+ }// //GEN-END:initComponents
+
+ private void buttonZoomFitActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonZoomFitActionPerformed
+ try {
+ renderer.setMode(RendererMode.Fit);
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonZoomFitActionPerformed
+
+ private void buttonZoomStretchActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonZoomStretchActionPerformed
+ try {
+ renderer.setMode(RendererMode.Stretch);
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonZoomStretchActionPerformed
+
+ private void buttonZoomNormalActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonZoomNormalActionPerformed
+ try {
+ renderer.setMode(RendererMode.Fixed);
+ centralizeRenderer();
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonZoomNormalActionPerformed
+
+ private void onChangeColormap(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_onChangeColormap
+ try {
+ if ((camera != null) && (camera instanceof ColormapSource) && !updatingColormap) {
+ ColormapSource source = (ColormapSource) camera;
+ Color colorReticule = new Color(16, 16, 16);
+ Color colorMarker = new Color(128, 128, 128);
+ Colormap colormap = (Colormap) comboColormap.getSelectedItem();
+ source.getConfig().colormap = (colormap == null) ? Colormap.Flame : colormap;
+ switch (source.getConfig().colormap) {
+ case Grayscale:
+ case Inverted:
+ case Red:
+ case Green:
+ case Blue:
+ colorReticule = new Color(0, 192, 0);
+ colorMarker = new Color(64, 255, 64);
+ break;
+ case Flame:
+ colorReticule = new Color(0, 192, 0);
+ colorMarker = new Color(64, 255, 64);
+ break;
+ }
+
+ renderer.setPenReticle(new Pen(colorReticule));
+ renderer.setPenProfile(new Pen(colorReticule, 0));
+ renderer.setPenMarker(new Pen(colorMarker, 2));
+ renderer.setShowReticle(false);
+ checkReticle();
+ source.getConfig().colormapAutomatic = buttonAutomatic.isSelected();
+ source.getConfig().colormapMin = buttonFullRange.isSelected() ? Double.NaN : (Integer) spinnerMin.getValue();
+ source.getConfig().colormapMax = buttonFullRange.isSelected() ? Double.NaN : (Integer) spinnerMax.getValue();
+ try {
+ source.getConfig().save();
+ } catch (Exception ex) {
+ Logger.getLogger(getClass().getName()).log(Level.WARNING, null, ex);
+ }
+ source.refresh();
+ if (buttonPause.isSelected()) {
+ updatePause();
+ }
+ updateColormap();
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_onChangeColormap
+
+ private void onChangeColormapRange(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_onChangeColormapRange
+ onChangeColormap(null);
+ }//GEN-LAST:event_onChangeColormapRange
+
+ private void buttonZoom025ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonZoom025ActionPerformed
+ renderer.setZoom(0.25);
+ renderer.setMode(RendererMode.Zoom);
+ centralizeRenderer();
+ }//GEN-LAST:event_buttonZoom025ActionPerformed
+
+ private void buttonZoom05ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonZoom05ActionPerformed
+ renderer.setZoom(0.5);
+ renderer.setMode(RendererMode.Zoom);
+ centralizeRenderer();
+ }//GEN-LAST:event_buttonZoom05ActionPerformed
+
+ private void buttonServerActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonServerActionPerformed
+ if (!usingServer) {
+ usingServer = true;
+ requestCameraListUpdate = true;
+ }
+ comboCamerasActionPerformed(null);
+ }//GEN-LAST:event_buttonServerActionPerformed
+
+ private void buttonDirectActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonDirectActionPerformed
+ if (usingServer) {
+ usingServer = false;
+ requestCameraListUpdate = true;
+ }
+ comboCamerasActionPerformed(null);
+ }//GEN-LAST:event_buttonDirectActionPerformed
+
+ private void comboScreenActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_comboScreenActionPerformed
+
+ comboScreen.setEnabled(false);
+ new Thread(new Runnable() {
+ @Override
+ public void run() {
+ ChannelInteger setpoint = null;
+ try {
+ int index = comboScreen.getSelectedIndex();
+ if (index >= 0) {
+ if (cameraName.contains("DSRM")) {
+ setpoint = new ChannelInteger(null, cameraName + ":POSITION_SP");
+ } else {
+ setpoint = new ChannelInteger(null, cameraName + ":SET_SCREEN1_POS");
+ }
+ setpoint.initialize();
+ Integer readback = setpoint.read();
+ if ((readback == null) || (setpoint.read() != index)) {
+ setpoint.write(index);
+ //Must be threaded to control the laser because of sleep in setLaserState
+ /*
+ boolean laserOn = getLaserState();
+ if (laserOn) {
+ setLaserState(false);
+ }
+ try {
+ setpoint.write(index);
+ } finally {
+ if (laserOn) {
+ setLaserState(true);
+ }
+ }
+ */
+ }
+ screen.read();
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ } finally {
+ comboScreen.setEnabled(true);
+ if (setpoint != null) {
+ setpoint.close();
+ }
+ }
+ }
+ }).start();
+ }//GEN-LAST:event_comboScreenActionPerformed
+
+ private void comboFilterActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_comboFilterActionPerformed
+ try {
+ String setpoint = (String) comboFilter.getSelectedItem();
+ if (setpoint != null) {
+ if (!setpoint.equals(filter.read())) {
+ filter.write(setpoint);
+ }
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_comboFilterActionPerformed
+
+ private void checkHistogramActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_checkHistogramActionPerformed
+ try {
+ setHistogramVisible(checkHistogram.isSelected());
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_checkHistogramActionPerformed
+
+ private void buttonZoom2ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonZoom2ActionPerformed
+ renderer.setZoom(2.0);
+ renderer.setMode(RendererMode.Zoom);
+ centralizeRenderer();
+ }//GEN-LAST:event_buttonZoom2ActionPerformed
+
+ private void spinnerThresholdonChange(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerThresholdonChange
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ server.setThreshold((Double) spinnerThreshold.getValue());
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_spinnerThresholdonChange
+
+ private void checkBackgroundActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_checkBackgroundActionPerformed
+ if (server != null) {
+ if (!updatingServerControls) {
+ try {
+ if (server.isStarted()) {
+ server.setBackgroundSubtraction(checkBackground.isSelected());
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ updatingServerControls = true;
+ checkBackground.setSelected(false);
+ updatingServerControls = false;
+
+ }
+ }
+ } else {
+ camera.setBackgroundEnabled(checkBackground.isSelected());
+ }
+ }//GEN-LAST:event_checkBackgroundActionPerformed
+
+ private void checkThresholdActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_checkThresholdActionPerformed
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ spinnerThreshold.setVisible(checkThreshold.isSelected());
+ server.setThreshold(checkThreshold.isSelected() ? (Double) spinnerThreshold.getValue() : null);
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_checkThresholdActionPerformed
+
+ private void checkGoodRegionActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_checkGoodRegionActionPerformed
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ goodRegion = checkGoodRegion.isSelected();
+ setGoodRegionOptionsVisible(goodRegion);
+ if (goodRegion) {
+ server.setGoodRegion(((Number) spinnerGrThreshold.getValue()).doubleValue(), ((Number) spinnerGrScale.getValue()).doubleValue());
+ } else {
+ server.setGoodRegion(null);
+ }
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_checkGoodRegionActionPerformed
+
+ private void spinnerGrThresholdonChange(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerGrThresholdonChange
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ server.setGoodRegion((Double) spinnerGrThreshold.getValue(), (Double) spinnerGrScale.getValue());
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_spinnerGrThresholdonChange
+
+ private void btFixColormapRangeActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btFixColormapRangeActionPerformed
+ try {
+ updatingColormap = true;
+ ArrayProperties properties = currentFrame.data.getProperties();
+ spinnerMax.setValue(properties.max.intValue());
+ spinnerMin.setValue(properties.min.intValue());
+ buttonManual.setSelected(true);
+ } catch (Exception ex) {
+ showException(ex);
+ } finally {
+ updatingColormap = false;
+ onChangeColormap(null);
+ }
+ }//GEN-LAST:event_btFixColormapRangeActionPerformed
+
+ private void checkSlicingActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_checkSlicingActionPerformed
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ slicing = checkSlicing.isSelected();
+ setSlicingOptionsVisible(slicing);
+ if (slicing) {
+ server.setSlicing((Integer) spinnerSlNumber.getValue(), (Double) spinnerSlScale.getValue(), spinnerSlOrientation.getValue().toString());
+ } else {
+ server.setSlicing(null);
+ }
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_checkSlicingActionPerformed
+
+ private void spinnerSlicingChange(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerSlicingChange
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ server.setSlicing((Integer) spinnerSlNumber.getValue(), (Double) spinnerSlScale.getValue(), spinnerSlOrientation.getValue().toString());
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_spinnerSlicingChange
+
+ private void buttonReticleActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonReticleActionPerformed
+ try {
+ checkReticle();
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonReticleActionPerformed
+
+ private void buttonFitActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonFitActionPerformed
+ try {
+ showFit = buttonFit.isSelected();
+ if (showFit) {
+ renderer.setProfile(Renderer.Profile.None);
+ } else {
+ renderer.removeOverlays(fitOv);
+ fitOv = null;
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonFitActionPerformed
+
+ private void buttonProfileActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonProfileActionPerformed
+ try {
+ showProfile = buttonProfile.isSelected();
+ if (showProfile) {
+ renderer.setProfile(Renderer.Profile.None);
+ } else {
+ renderer.removeOverlays(profileOv);
+ profileOv = null;
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonProfileActionPerformed
+
+ private void buttonMarkerActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonMarkerActionPerformed
+ try {
+ checkMarker(null);
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonMarkerActionPerformed
+
+ private void buttonPauseActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonPauseActionPerformed
+ try {
+ if (!updatingButtons) {
+ setPaused(buttonPause.isSelected());
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonPauseActionPerformed
+
+ private void buttonGrabBackgroundActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonGrabBackgroundActionPerformed
+ try {
+ if (camera != null) {
+ boolean laserOn1 = getLaserState(1);
+ boolean laserOn2 = getLaserState(2);
+ OptionResult ret = null;
+ if (laserOn1 || laserOn2) {
+ if (laserOn1){
+ ret = SwingUtils.showOption(getTopLevel(), "Capture Background", "Do you want to put Bunch 1 laser on delay for capturing background?", OptionType.YesNoCancel);
+ if (ret == OptionResult.No) {
+ laserOn1 = false;
+ }
+ if (ret == OptionResult.Cancel) {
+ return;
+ }
+ }
+ if (laserOn2){
+ ret = SwingUtils.showOption(getTopLevel(), "Capture Background", "Do you want to put Bunch 2 laser on delay for capturing background?", OptionType.YesNoCancel);
+ if (ret == OptionResult.No) {
+ laserOn2= false;
+ }
+ }
+ } else {
+ ret = SwingUtils.showOption(getTopLevel(), "Capture Background", "Do you want to capture background now?", OptionType.OkCancel);
+ }
+
+ if (ret == OptionResult.Cancel) {
+ return;
+ }
+
+ if (laserOn1) {
+ setLaserState(1,false);
+ }
+ if (laserOn2) {
+ setLaserState(2,false);
+ }
+ try {
+ System.out.println("Grabbing background for: " + cameraName);
+ if (server != null) {
+ server.captureBackground(5);
+ } else {
+ camera.captureBackground(5, 0);
+ }
+ } finally {
+ if (laserOn1) {
+ setLaserState(1,true);
+ }
+ if (laserOn2) {
+ setLaserState(2,true);
+ }
+ }
+ SwingUtils.showMessage(getTopLevel(), "Success", "Success capturing background", 5000);
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonGrabBackgroundActionPerformed
+
+ private void buttonSaveActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonSaveActionPerformed
+ try {
+ saveSnapshot();
+ } catch (Exception ex) {
+ Logger.getLogger(getClass().getName()).log(Level.WARNING, null, ex);
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonSaveActionPerformed
+
+ private void buttonStreamDataActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonStreamDataActionPerformed
+ try {
+ showStreamData();
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonStreamDataActionPerformed
+
+ private void buttonSidePanelActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonSidePanelActionPerformed
+ sidePanel.setVisible(buttonSidePanel.isSelected());
+ }//GEN-LAST:event_buttonSidePanelActionPerformed
+
+ private void comboTypeActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_comboTypeActionPerformed
+ try {
+ if (!updatingCameraSelection) {
+ updateCameraList();
+ if ((cameraName != null) && (!cameraName.equals(comboCameras.getSelectedItem()))) {
+ setCamera(null);
+ } else {
+ setCamera(cameraName);
+ }
+ }
+
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ } finally {
+ updateButtons();
+ }
+ }//GEN-LAST:event_comboTypeActionPerformed
+
+ private void comboCamerasActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_comboCamerasActionPerformed
+ try {
+ if (!updatingCameraSelection) {
+ if (!comboCameras.isEnabled()) {
+ throw new Exception("Invalid state");
+ }
+ comboCameras.setEnabled(false);
+ comboType.setEnabled(false);
+ buttonServer.setEnabled(false);
+ buttonDirect.setEnabled(false);
+ final String cameraName = (String) comboCameras.getSelectedItem();
+ new Thread(new Runnable() {
+ @Override
+ public void run() {
+ if (requestCameraListUpdate) {
+ requestCameraListUpdate = false;
+ try {
+ updateCameraList();
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ try {
+ setCamera(cameraName.trim().isEmpty() ? null : cameraName);
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ } finally {
+ updateButtons();
+ comboCameras.setEnabled(true);
+ comboType.setEnabled(true);
+ buttonServer.setEnabled(true);
+ buttonDirect.setEnabled(true);
+ }
+ }
+ }).start();
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_comboCamerasActionPerformed
+
+ private void buttonTitleActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonTitleActionPerformed
+ try {
+ manageTitleOverlay();
+ } catch (Exception ex) {
+ showException(ex);
+ } finally {
+ }
+ }//GEN-LAST:event_buttonTitleActionPerformed
+
+ private void buttonScaleActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonScaleActionPerformed
+ try {
+ renderer.setShowColormapScale(buttonScale.isSelected());
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonScaleActionPerformed
+
+ private void checkRotationActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_checkRotationActionPerformed
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ boolean rotation = checkRotation.isSelected();
+ setRotationOptionsVisible(rotation);
+ if (rotation) {
+ spinnerRotationAngleStateChanged(null);
+ } else {
+ server.setRotation(null);
+ }
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_checkRotationActionPerformed
+
+ private void spinnerRotationAngleStateChanged(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerRotationAngleStateChanged
+ try {
+ String mode = String.valueOf(spinnerRotationMode.getValue());
+ server.setRotation(((Number) spinnerRotationAngle.getValue()).doubleValue(),
+ ((Number) spinnerRotationOrder.getValue()).intValue(),
+ mode.equals("constant") ? String.valueOf(spinnerRotationConstant.getValue()): mode);
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }//GEN-LAST:event_spinnerRotationAngleStateChanged
+
+ // Variables declaration - do not modify//GEN-BEGIN:variables
+ private javax.swing.JButton btFixColormapRange;
+ private javax.swing.JRadioButton buttonAutomatic;
+ private javax.swing.JRadioButton buttonDirect;
+ private javax.swing.JToggleButton buttonFit;
+ private javax.swing.JRadioButton buttonFullRange;
+ private javax.swing.JButton buttonGrabBackground;
+ private javax.swing.ButtonGroup buttonGroup1;
+ private javax.swing.ButtonGroup buttonGroup2;
+ private javax.swing.ButtonGroup buttonGroup3;
+ private javax.swing.ButtonGroup buttonGroup4;
+ private javax.swing.JRadioButton buttonManual;
+ private javax.swing.JToggleButton buttonMarker;
+ private javax.swing.JToggleButton buttonPause;
+ private javax.swing.JToggleButton buttonProfile;
+ private javax.swing.JToggleButton buttonReticle;
+ private javax.swing.JToggleButton buttonSave;
+ private javax.swing.JToggleButton buttonScale;
+ private javax.swing.JRadioButton buttonServer;
+ private javax.swing.JToggleButton buttonSidePanel;
+ private javax.swing.JButton buttonStreamData;
+ private javax.swing.JToggleButton buttonTitle;
+ private javax.swing.JRadioButton buttonZoom025;
+ private javax.swing.JRadioButton buttonZoom05;
+ private javax.swing.JRadioButton buttonZoom2;
+ private javax.swing.JRadioButton buttonZoomFit;
+ private javax.swing.JRadioButton buttonZoomNormal;
+ private javax.swing.JRadioButton buttonZoomStretch;
+ private javax.swing.JCheckBox checkBackground;
+ private javax.swing.JCheckBox checkGoodRegion;
+ private javax.swing.JCheckBox checkHistogram;
+ private javax.swing.JCheckBox checkRotation;
+ private javax.swing.JCheckBox checkSlicing;
+ private javax.swing.JCheckBox checkThreshold;
+ private javax.swing.JComboBox comboCameras;
+ private javax.swing.JComboBox comboColormap;
+ private javax.swing.JComboBox comboFilter;
+ private javax.swing.JComboBox comboScreen;
+ private javax.swing.JComboBox comboType;
+ private javax.swing.Box.Filler filler1;
+ private javax.swing.JLabel jLabel1;
+ private javax.swing.JLabel jLabel3;
+ private javax.swing.JLabel jLabel4;
+ private javax.swing.JLabel jLabel5;
+ private javax.swing.JPanel jPanel2;
+ private javax.swing.JPanel jPanel3;
+ private javax.swing.JPanel jPanel5;
+ private javax.swing.JProgressBar jProgressBar1;
+ private javax.swing.JToolBar.Separator jSeparator6;
+ private javax.swing.JLabel labelAngle;
+ private javax.swing.JLabel labelConstant;
+ private javax.swing.JLabel labelGrScale;
+ private javax.swing.JLabel labelGrThreshold;
+ private javax.swing.JLabel labelMax;
+ private javax.swing.JLabel labelMin;
+ private javax.swing.JLabel labelMode;
+ private javax.swing.JLabel labelOrder;
+ private javax.swing.JLabel labelSlNumber;
+ private javax.swing.JLabel labelSlOrientation;
+ private javax.swing.JLabel labelSlScale;
+ private javax.swing.JPanel panelCameraSelection;
+ private javax.swing.JPanel panelFilter;
+ private javax.swing.JPanel panelScreen;
+ private javax.swing.JPanel panelScreen2;
+ private javax.swing.JPanel panelSlicing;
+ private ch.psi.pshell.swing.ValueSelection pauseSelection;
+ private ch.psi.pshell.imaging.Renderer renderer;
+ private javax.swing.JPanel sidePanel;
+ private javax.swing.JSpinner spinnerGrScale;
+ private javax.swing.JSpinner spinnerGrThreshold;
+ private javax.swing.JSpinner spinnerMax;
+ private javax.swing.JSpinner spinnerMin;
+ private javax.swing.JSpinner spinnerRotationAngle;
+ private javax.swing.JSpinner spinnerRotationConstant;
+ private javax.swing.JSpinner spinnerRotationMode;
+ private javax.swing.JSpinner spinnerRotationOrder;
+ private javax.swing.JSpinner spinnerSlNumber;
+ private javax.swing.JSpinner spinnerSlOrientation;
+ private javax.swing.JSpinner spinnerSlScale;
+ private javax.swing.JSpinner spinnerThreshold;
+ private javax.swing.JTextField textState;
+ private javax.swing.JToolBar toolBar;
+ private javax.swing.JPanel topPanel;
+ private ch.psi.pshell.swing.DeviceValuePanel valueFilter;
+ private ch.psi.pshell.swing.DeviceValuePanel valueScreen;
+ // End of variables declaration//GEN-END:variables
+}
diff --git a/plugins/ScreenPanel6.form b/plugins/ScreenPanel6.form
new file mode 100644
index 0000000..dabc144
--- /dev/null
+++ b/plugins/ScreenPanel6.form
@@ -0,0 +1,1370 @@
+
+
+
diff --git a/plugins/ScreenPanel6.java b/plugins/ScreenPanel6.java
new file mode 100644
index 0000000..f104956
--- /dev/null
+++ b/plugins/ScreenPanel6.java
@@ -0,0 +1,4558 @@
+/*
+ * Copyright (c) 2014 Paul Scherrer Institute. All rights reserved.
+ */
+
+import ch.psi.pshell.bs.CameraServer;
+import ch.psi.pshell.core.Context;
+import java.io.IOException;
+import java.nio.file.Paths;
+import javax.swing.DefaultComboBoxModel;
+import ch.psi.pshell.ui.Panel;
+import ch.psi.pshell.imaging.ImageListener;
+import ch.psi.utils.State;
+import ch.psi.utils.Chrono;
+import ch.psi.utils.swing.SwingUtils;
+import ch.psi.utils.swing.TextEditor;
+import ch.psi.pshell.bs.PipelineServer;
+import ch.psi.pshell.bs.StreamValue;
+import ch.psi.pshell.core.JsonSerializer;
+import ch.psi.pshell.data.DataManager;
+import ch.psi.pshell.device.Device;
+import ch.psi.pshell.device.Readable.ReadableArray;
+import ch.psi.pshell.device.Readable.ReadableNumber;
+import ch.psi.pshell.device.ReadableRegister.ReadableRegisterArray;
+import ch.psi.pshell.device.ReadableRegister.ReadableRegisterNumber;
+import ch.psi.pshell.epics.ChannelInteger;
+import ch.psi.pshell.epics.DiscretePositioner;
+import ch.psi.pshell.epics.Epics;
+import ch.psi.pshell.imaging.Colormap;
+import ch.psi.pshell.imaging.ColormapSource;
+import ch.psi.pshell.imaging.ColormapSource.ColormapSourceConfig;
+import ch.psi.pshell.ui.App;
+import ch.psi.pshell.imaging.Data;
+import ch.psi.pshell.imaging.DimensionDouble;
+import ch.psi.pshell.imaging.Histogram;
+import ch.psi.pshell.imaging.ImageBuffer;
+import ch.psi.pshell.imaging.Overlay;
+import ch.psi.pshell.imaging.Overlays;
+import ch.psi.pshell.imaging.Overlays.Text;
+import ch.psi.pshell.imaging.Pen;
+import ch.psi.pshell.imaging.PointDouble;
+import ch.psi.pshell.imaging.Renderer;
+import ch.psi.pshell.imaging.RendererListener;
+import ch.psi.pshell.imaging.RendererMode;
+import ch.psi.pshell.imaging.Source;
+import ch.psi.pshell.scripting.InterpreterResult;
+import ch.psi.pshell.scripting.ScriptManager;
+import ch.psi.pshell.swing.DeviceValueChart;
+import ch.psi.pshell.swing.ValueSelection;
+import ch.psi.pshell.swing.ValueSelection.ValueSelectionListener;
+import ch.psi.pshell.ui.Console;
+import ch.psi.utils.Arr;
+import ch.psi.utils.ArrayProperties;
+import ch.psi.utils.Config;
+import ch.psi.utils.Convert;
+import ch.psi.utils.Str;
+import ch.psi.utils.swing.Editor.EditorDialog;
+import ch.psi.utils.swing.MainFrame;
+import ch.psi.utils.swing.StandardDialog;
+import ch.psi.utils.swing.StandardDialog.StandardDialogListener;
+import ch.psi.utils.swing.SwingUtils.OptionResult;
+import ch.psi.utils.swing.SwingUtils.OptionType;
+import java.awt.Color;
+import java.awt.Component;
+import java.awt.Dimension;
+import java.awt.Font;
+import java.awt.GridBagConstraints;
+import java.awt.GridBagLayout;
+import java.awt.Point;
+import java.awt.Rectangle;
+import java.awt.Toolkit;
+import java.awt.datatransfer.Clipboard;
+import java.awt.datatransfer.StringSelection;
+import java.awt.datatransfer.Transferable;
+import java.awt.event.ActionEvent;
+import java.awt.event.MouseAdapter;
+import java.awt.event.MouseEvent;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.awt.image.BufferedImage;
+import java.io.File;
+import java.io.FileInputStream;
+import java.lang.reflect.Array;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Properties;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+import javax.swing.ImageIcon;
+import javax.swing.JButton;
+import javax.swing.JCheckBox;
+import javax.swing.JCheckBoxMenuItem;
+import javax.swing.JComboBox;
+import javax.swing.JComponent;
+import javax.swing.JDialog;
+import javax.swing.JLabel;
+import javax.swing.JMenu;
+import javax.swing.JMenuItem;
+import javax.swing.JPanel;
+import javax.swing.JScrollPane;
+import javax.swing.JSpinner;
+import javax.swing.JTable;
+import javax.swing.JTextField;
+import javax.swing.ListSelectionModel;
+import javax.swing.SwingUtilities;
+import javax.swing.event.PopupMenuEvent;
+import javax.swing.event.PopupMenuListener;
+import javax.swing.table.DefaultTableModel;
+import org.apache.commons.math3.analysis.function.Gaussian;
+import org.apache.commons.math3.fitting.GaussianCurveFitter;
+import org.apache.commons.math3.fitting.PolynomialCurveFitter;
+import org.apache.commons.math3.fitting.WeightedObservedPoint;
+import org.apache.commons.math3.stat.descriptive.DescriptiveStatistics;
+
+/**
+ *
+ */
+public class ScreenPanel6 extends Panel {
+
+ public static final String LASER_TYPE = "Laser";
+ public static final String ELECTRONS_TYPE = "Electrons";
+ public static final String PHOTONICS_TYPE = "Photonics";
+
+ final String CAMERA_DEVICE_NAME = "CurrentCamera";
+ boolean useServerStats = true;
+ String userOverlaysConfigFile;
+ ColormapSource camera;
+ PipelineServer server;
+ String cameraName;
+ int polling = 1000;
+ Overlay marker = null;
+ JDialog histogramDialog;
+ DiscretePositioner screen;
+ DiscretePositioner filter;
+ boolean showFit;
+ boolean showProfile;
+ Overlay[] userOv;
+ Overlay[] fitOv;
+ Overlay[] profileOv;
+ Overlay errorOverlay;
+ boolean requestCameraListUpdate;
+ boolean goodRegion;
+ boolean slicing;
+ String serverUrl;
+ String camServerUrl;
+ String instanceName;
+ Overlay titleOv = null;
+ //int integration = 0;
+ boolean persistCameraState;
+
+ public class CameraState extends Config {
+
+ public boolean valid;
+ public boolean showSidePanel;
+ //public boolean showMarker; Saved in the stream instance config
+ public boolean showProfile;
+ public boolean showFit;
+ public boolean showReticle;
+ public boolean showScale;
+ public boolean showTitle;
+ public double zoom;
+ public RendererMode mode;
+ public boolean colormapAutomatic;
+ public double colormapMin;
+ public double colormapMax;
+ public Colormap colormap;
+ public boolean colormapLogarithmic;
+
+ String getFile() {
+ if (camera == null) {
+ return null;
+ }
+ return getContext().getSetup().expandPath("{context}/screen_panel/" + cameraName + ".properties");
+ }
+ }
+
+ void loadCameraState() {
+ if (persistCameraState) {
+ try {
+ CameraState state = new CameraState();
+ state.load(state.getFile());
+ if (state.valid) {
+ buttonSidePanel.setSelected(state.showSidePanel);
+ buttonSidePanelActionPerformed(null);
+ buttonProfile.setSelected(state.showProfile);
+ buttonProfileActionPerformed(null);
+ buttonFit.setSelected(state.showFit);
+ buttonFitActionPerformed(null);
+ buttonReticle.setSelected(state.showReticle);
+ buttonReticleActionPerformed(null);
+ buttonScale.setSelected(state.showScale);
+ buttonScaleActionPerformed(null);
+ buttonTitle.setSelected(state.showTitle);
+ buttonTitleActionPerformed(null);
+ renderer.setMode(state.mode);
+ renderer.setZoom(state.zoom);
+ if (camera instanceof ColormapSource) {
+ camera.getConfig().colormap = state.colormap;
+ camera.getConfig().colormapAutomatic = state.colormapAutomatic;
+ camera.getConfig().colormapLogarithmic = state.colormapLogarithmic;
+ camera.getConfig().colormapMax = state.colormapMax;
+ camera.getConfig().colormapMin = state.colormapMin;
+ updateColormap();
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ }
+
+ void saveCameraState() {
+ if (persistCameraState) {
+ try {
+ CameraState state = new CameraState();
+ state.valid = true;
+ if (camera instanceof ColormapSource) {
+ state.colormap = camera.getConfig().colormap;
+ state.colormapAutomatic = camera.getConfig().colormapAutomatic;
+ state.colormapLogarithmic = camera.getConfig().colormapLogarithmic;
+ state.colormapMax = camera.getConfig().colormapMax;
+ state.colormapMin = camera.getConfig().colormapMin;
+ }
+ state.mode = renderer.getMode();
+ state.zoom = renderer.getZoom();
+
+ state.showSidePanel = buttonSidePanel.isSelected();
+ state.showProfile = buttonProfile.isSelected();
+ state.showFit = buttonFit.isSelected();
+ state.showReticle = buttonReticle.isSelected();
+ state.showScale = buttonScale.isSelected();
+ state.showTitle = buttonTitle.isSelected();
+
+ state.save(state.getFile());
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ }
+
+ String pipelineSuffix = "_sp";
+
+ Double getServerDouble(String name) {
+ return (Double) Convert.toDouble(server.getValue(name));
+ }
+
+ double[] getServerDoubleArray(String name) {
+ return (double[]) Convert.toDouble(server.getValue(name));
+ }
+
+ class ImageData {
+
+ ImageData() {
+ if (server != null) {
+ cache = server.getStream().take();
+ String prefix = goodRegion ? "gr_" : "";
+ x_fit_mean = getDouble(prefix + "x_fit_mean");
+ y_fit_mean = getDouble(prefix + "y_fit_mean");
+ x_fit_standard_deviation = getDouble(prefix + "x_fit_standard_deviation");
+ y_fit_standard_deviation = getDouble(prefix + "y_fit_standard_deviation");
+ x_fit_gauss_function = getDoubleArray(prefix + "x_fit_gauss_function");
+ y_fit_gauss_function = getDoubleArray(prefix + "y_fit_gauss_function");
+ x_profile = getDoubleArray("x_profile");
+ y_profile = getDoubleArray("y_profile");
+ x_center_of_mass = getDouble("x_center_of_mass");
+ y_center_of_mass = getDouble("y_center_of_mass");
+ x_rms = getDouble("x_rms");
+ y_rms = getDouble("y_rms");
+ if (goodRegion) {
+ double[] gX2 = new double[x_profile.length];
+ Arrays.fill(gX2, Double.NaN);
+ try {
+ double[] axis = getDoubleArray("x_axis");
+ gr_x_axis = getDoubleArray("gr_x_axis");
+ double x = gr_x_axis[0];
+ gr_size_x = x_fit_gauss_function.length;
+ //If gr axis values are not identical, calculate the index...
+ gr_pos_x = (int) ((renderer.getCalibration() != null) ? renderer.getCalibration().convertToImageX(x) : x);
+ //But prefer checking the value to avoid raounding errors
+ for (int i=0;i imageBuffer = new ArrayList();
+ Frame currentFrame;
+ int imageBufferLenght = 1;
+ Text imagePauseOverlay;
+ final Console console;
+
+ public ScreenPanel6() {
+ try {
+ initComponents();
+ spinnerThreshold.setVisible(false);
+ btFixColormapRange.setVisible(false);
+ setGoodRegionOptionsVisible(false);
+ setSlicingOptionsVisible(false);
+ setRotationOptionsVisible(false);
+ setAveragingOptionsVisible(false);
+ JComponent editor = spinnerSlOrientation.getEditor();
+ if (editor instanceof JSpinner.DefaultEditor) {
+ ((JSpinner.DefaultEditor) editor).getTextField().setHorizontalAlignment(JTextField.RIGHT);
+ }
+ renderer.setPersistenceFile(Paths.get(getContext().getSetup().getContextPath(), "Renderer_Cameras.bin"));
+ //setPersistedComponents(new Component[]{buttonServer, buttonDirect});
+ setPersistedComponents(new Component[]{buttonTitle});
+ comboCameras.setEnabled(false);
+ comboType.setEnabled(false);
+
+ SwingUtils.setEnumCombo(comboColormap, Colormap.class);
+ if (App.hasArgument("poll")) {
+ try {
+ polling = Integer.valueOf(App.getArgumentValue("poll"));
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ if (App.hasArgument("zoom")) {
+ try {
+ renderer.setDefaultZoom(Double.valueOf(App.getArgumentValue("zoom")));
+ renderer.resetZoom();
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ if (App.hasArgument("buf")) {
+ try {
+ imageBufferLenght = Integer.valueOf(App.getArgumentValue("buf"));
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+
+ if (App.hasArgument("usr_ov")) {
+ try {
+ userOverlaysConfigFile = App.getArgumentValue("usr_ov");
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+
+ if (App.hasArgument("srv_url")) {
+ serverUrl = App.getArgumentValue("srv_url");
+ }
+
+ if (App.hasArgument("cam_srv_url")) {
+ camServerUrl = App.getArgumentValue("cam_srv_url");
+ }
+
+ if (App.hasArgument("calc")) {
+ useServerStats = false;
+ }
+
+ if (App.hasArgument("persist")) {
+ persistCameraState = true;
+ }
+
+ if (App.hasArgument("suffix")) {
+ pipelineSuffix = App.getArgumentValue("suffix");
+ }
+ /*
+ if (App.hasArgument("integration")) {
+ try {
+ setIntegration(Integer.valueOf(App.getArgumentValue("integration")));
+ if (integration != 0) {
+ buttonFit.setSelected(false);
+ buttonProfile.setSelected(false);
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ */
+
+ renderer.setProfileNormalized(true);
+ renderer.setShowProfileLimits(false);
+
+ JMenuItem menuCalibrate = new JMenuItem("Calibrate...");
+ menuCalibrate.addActionListener((ActionEvent e) -> {
+ try {
+ calibrate();
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ });
+
+ JMenuItem menuRendererConfig = new JMenuItem("Renderer Parameters");
+ menuRendererConfig.addActionListener((ActionEvent e) -> {
+ try {
+ if (camera != null) {
+ this.showDeviceConfigDialog(camera, false);
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ });
+
+ JMenuItem menuCameraConfig = new JMenuItem("Camera Configurarion");
+ menuCameraConfig.addActionListener((ActionEvent e) -> {
+ try {
+ if (camera != null) {
+ String cameraConfigJson = null;
+ if (usingServer) {
+ String cameraServerUrl = (camServerUrl == null) ? server.getUrl().substring(0, server.getUrl().length() - 1) + "8" : camServerUrl;
+ try (CameraServer srv = new CameraServer("CamServer", cameraServerUrl)) {
+ srv.initialize();
+ //TODO: replace into encodeMultiline
+ cameraConfigJson = JsonSerializer.encode(srv.getConfig(cameraName), true);
+ }
+
+ } else {
+ String configFolder = (String) getContext().getClassByName("SfCamera").getMethod("getConfigFolder", new Class[]{}).invoke(null);
+ Path configFile = Paths.get(configFolder, cameraName + ".json");
+ cameraConfigJson = configFile.toFile().exists() ? new String(Files.readAllBytes(configFile)) : null;
+ }
+ TextEditor configEditor = new TextEditor();
+ configEditor.setText(cameraConfigJson);
+ configEditor.setReadOnly(true);
+ configEditor.setTitle(cameraName);
+ EditorDialog dlg = configEditor.getDialog(getTopLevel(), false);
+ dlg.setSize(480, 640);
+ dlg.setVisible(true);
+ SwingUtils.centerComponent(getTopLevel(), dlg);
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ });
+
+ JMenuItem menuSetImageBufferSize = new JMenuItem("Set Stack Size...");
+ menuSetImageBufferSize.addActionListener((ActionEvent e) -> {
+ try {
+ String ret = SwingUtils.getString(getTopLevel(), "Enter size of image buffer: ", String.valueOf(imageBufferLenght));
+ if (ret != null) {
+ this.setImageBufferSize(Integer.valueOf(ret));
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ });
+
+ JMenuItem menuSaveStack = new JMenuItem("Save Stack");
+ menuSaveStack.addActionListener((ActionEvent e) -> {
+ try {
+ saveStack();
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ });
+
+ JMenuItem menuSetROI = new JMenuItem("Set ROI...");
+ menuSetROI.addActionListener((ActionEvent e) -> {
+ renderer.abortSelection();
+ if (server != null) {
+ final Overlays.Rect selection = new Overlays.Rect(renderer.getPenMovingOverlay());
+ renderer.addListener(new RendererListener() {
+ @Override
+ public void onSelectionFinished(Renderer renderer, Overlay overlay) {
+ try {
+ renderer.setShowReticle(false);
+ Rectangle roi = overlay.isFixed() ? renderer.toImageCoord(overlay.getBounds()) : overlay.getBounds();
+ if (server.isRoiEnabled()) {
+ int[] cur = server.getRoi();
+ server.setRoi(new int[]{roi.x + cur[0], roi.y + cur[1], roi.width, roi.height});
+ } else {
+ server.setRoi(new int[]{roi.x, roi.y, roi.width, roi.height});
+ }
+ } catch (Exception ex) {
+ } finally {
+ renderer.removeListener(this);
+ }
+ }
+
+ @Override
+ public void onSelectionAborted(Renderer renderer, Overlay overlay) {
+ renderer.removeListener(this);
+ }
+ });
+ selection.setFixed(true);
+ renderer.startSelection(selection);
+ }
+ });
+
+ JMenuItem menuResetROI = new JMenuItem("Reset ROI");
+ menuResetROI.addActionListener((ActionEvent e) -> {
+ renderer.abortSelection();
+ if (server != null) {
+ try {
+ renderer.setShowReticle(false);
+ server.resetRoi();
+ } catch (IOException ex) {
+ showException(ex);
+ }
+ }
+ });
+ /*
+ JCheckBoxMenuItem menuFrameIntegration = new JCheckBoxMenuItem("Multi-Frame", (integration != 0));
+ menuFrameIntegration.addActionListener((ActionEvent e) -> {
+ if (integration == 0) {
+ JPanel panel = new JPanel();
+ GridBagLayout layout = new GridBagLayout();
+ layout.columnWidths = new int[]{150, 50}; //Minimum width
+ layout.rowHeights = new int[]{30, 30}; //Minimum height
+ panel.setLayout(layout);
+ JCheckBox checkContinuous = new JCheckBox("");
+ checkContinuous.setSelected(true);
+ JTextField textFrames = new JTextField();
+ GridBagConstraints c = new GridBagConstraints();
+ c.gridx = 0;
+ c.gridy = 0;
+ panel.add(new JLabel("Number of frames:"), c);
+ c.gridy = 1;
+ panel.add(new JLabel("Continuous:"), c);
+ c.fill = GridBagConstraints.HORIZONTAL;
+ c.gridx = 1;
+ panel.add(checkContinuous, c);
+ c.gridy = 0;
+ panel.add(textFrames, c);
+ if (SwingUtils.showOption(getTopLevel(), "Multi-Frame Integration", panel, OptionType.OkCancel) == OptionResult.Yes) {
+ setIntegration(checkContinuous.isSelected() ? -(Integer.valueOf(textFrames.getText())) : (Integer.valueOf(textFrames.getText())));
+ }
+ } else {
+ if (SwingUtils.showOption(getTopLevel(), "Multi-Frame Integration",
+ "Do you want to disable " + ((integration < 0) ? "continuous " : "") + "multi-frame integration (" + Math.abs(integration) + ")?", OptionType.YesNo) == OptionResult.Yes) {
+ setIntegration(0);
+ }
+ }
+ });
+
+ for (Component cmp : SwingUtils.getComponentsByType(renderer.getPopupMenu(), JMenu.class)) {
+ JMenu menu = (JMenu) cmp;
+ if (menu.getText().equals("Integration")) {
+ menu.addSeparator();
+ menu.add(menuFrameIntegration);
+ }
+ }
+ */
+ renderer.getPopupMenu().addSeparator();
+ renderer.getPopupMenu().add(menuRendererConfig);
+ renderer.getPopupMenu().add(menuCameraConfig);
+ renderer.getPopupMenu().add(menuSetImageBufferSize);
+ renderer.getPopupMenu().add(menuSaveStack);
+ renderer.getPopupMenu().addSeparator();
+ renderer.getPopupMenu().add(menuCalibrate);
+ renderer.getPopupMenu().addSeparator();
+ renderer.getPopupMenu().add(menuSetROI);
+ renderer.getPopupMenu().add(menuResetROI);
+ renderer.getPopupMenu().addPopupMenuListener(new PopupMenuListener() {
+ @Override
+ public void popupMenuWillBecomeVisible(PopupMenuEvent e) {
+ menuResetROI.setEnabled(server != null);
+ menuSetROI.setEnabled(server != null);
+ menuCalibrate.setVisible(server != null);
+ menuCalibrate.setEnabled((calibrationDialolg == null) || (!calibrationDialolg.isShowing()));
+ menuSaveStack.setEnabled(imageBufferLenght > 0);
+ menuSetImageBufferSize.setEnabled(!renderer.isPaused());
+ //menuFrameIntegration.setSelected(integration != 0);
+ }
+
+ @Override
+ public void popupMenuWillBecomeInvisible(PopupMenuEvent e) {
+ }
+
+ @Override
+ public void popupMenuCanceled(PopupMenuEvent e) {
+ }
+ });
+ renderer.getPopupMenu().setVisible(false);
+ buttonScale.setSelected(renderer.getShowColormapScale());
+ clearMarker();
+
+ showFit = buttonFit.isSelected();
+ showProfile = buttonProfile.isSelected();
+
+ pauseSelection.setVisible(false);
+ pauseSelection.setMinValue(1);
+ pauseSelection.addListener(new ValueSelectionListener() {
+ @Override
+ public void onValueChanged(ValueSelection origin, double value, boolean editing) {
+ if (editing && (value >= 1) && (value <= imageBuffer.size())) {
+ updatePause();
+ }
+ }
+ });
+ renderer.addListener(new RendererListener() {
+ @Override
+ public void onMoveFinished(Renderer renderer, Overlay overlay) {
+ if (overlay == marker) {
+ try {
+ onMarkerChanged();
+ } catch (IOException ex) {
+ Logger.getLogger(ScreenPanel6.class.getName()).log(Level.WARNING, null, ex);
+ }
+ }
+ }
+ });
+ if (MainFrame.isDark()) {
+ textState.setDisabledTextColor(textState.getForeground());
+ }
+
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+
+ console = (!App.hasArgument("console")) ? null : new Console() {
+ /*
+ protected void onConsoleCommand(String name, String[] pars, String trimming) throws Exception {
+ switch (name) {
+ case "cam":
+ comboCameras.setSelectedItem(tokens[1]);
+ break;
+ }
+ }*/
+ @Override
+ protected void onConsoleCommand(String command) {
+ String[] tokens = command.split(" ");
+ if ((tokens.length > 1) && tokens[0].equals("cam")) {
+ try {
+ if (!tokens[1].equals(comboCameras.getSelectedItem())) {
+ setComboTypeSelection("All");
+ updateCameraList();
+ comboCameras.setSelectedItem(tokens[1]);
+ if (!tokens[1].equals(comboCameras.getSelectedItem())) {
+ comboCameras.setSelectedItem("");
+ throw new Exception("Invalid camera name : " + tokens[1]);
+ }
+ System.out.println("Console set camera: " + tokens[1]);
+ }
+ } catch (Exception ex) {
+ System.err.println(ex);
+ }
+ } else {
+ System.err.println("Invalid command: " + command);
+ }
+ }
+ };
+ }
+
+ /*
+ void setIntegration(int frames) {
+ try {
+ if (integration != frames) {
+ integration = frames;
+ if (camera != null) {
+ if (Math.abs(integration) > 1) {
+ renderer.setDevice(new ImageIntegrator(integration));
+ } else {
+ renderer.setDevice(camera);
+ }
+ synchronized (imageBuffer) {
+ currentFrame = null;
+ imageBuffer.clear();
+ }
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ */
+
+ @Override
+ public void onStart() {
+ super.onStart();
+ updateDialogTitle();
+ if (App.hasArgument("ct")) {
+ boolean direct = App.getArgumentValue("ct").equals("0") || App.getArgumentValue("ct").equalsIgnoreCase("false");
+ buttonServer.setSelected(!direct);
+ buttonDirect.setSelected(direct);
+ }
+ if (App.hasArgument("console")) {
+ console.start();
+ }
+ }
+
+ @Override
+ public void onStop() {
+ try {
+ if (camera != null) {
+ saveCameraState();
+ camera.close();
+ camera = null;
+ server = null;
+ updateButtons();
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ try {
+ if (console != null) {
+ console.stop();
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ super.onStop();
+ }
+
+ //Overridable callbacks
+ @Override
+ public void onInitialize(int runCount) {
+ comboCameras.setEnabled(false);
+ comboType.setEnabled(false);
+ if (App.hasArgument("s")) {
+ renderer.setDevice((Source) getDevice("image"));
+ renderer.setAutoScroll(true);
+ ((Source) getDevice("image")).addListener(new ImageListener() {
+ @Override
+ public void onImage(Object o, BufferedImage bi, Data data) {
+ manageFit(bi, data);
+ manageUserOverlays(bi, data);
+ }
+
+ @Override
+ public void onError(Object o, Exception ex) {
+ }
+ }
+ );
+
+ } else {
+ usingServer = buttonServer.isSelected();
+ updateCameraList();
+ comboCameras.setEnabled(true);
+ comboType.setEnabled(true);
+ setComboCameraSelection(null);
+ setComboTypeSelection("All");
+
+ if (comboCameras.getModel().getSize() > 0) {
+ try {
+ if (App.hasArgument("cam")) {
+ setComboCameraSelection(App.getArgumentValue("cam"));
+ comboCamerasActionPerformed(null);
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ }
+ updateButtons();
+ startTimer(1000);
+ }
+
+ boolean isVisible(String camera) {
+ return ((comboType.getSelectedIndex() == 0) || (getCameraType(camera).equals(comboType.getSelectedItem())));
+ }
+
+ DefaultComboBoxModel getCameraList(boolean fromServer) throws Exception {
+ DefaultComboBoxModel model = new DefaultComboBoxModel();
+ if (fromServer) {
+ try (PipelineServer srv = newServer()) {
+ srv.initialize();
+ List cameras = srv.getCameras();
+ Collections.sort(cameras);
+ for (String camera : cameras) {
+ if (isVisible(camera)) {
+ model.addElement(camera);
+ }
+ }
+ }
+
+ } else {
+ ArrayList cameras = (ArrayList) getContext().getClassByName("SfCamera").getMethod("getCameras", new Class[]{}).invoke(null);
+ for (String camera : cameras) {
+ if (isVisible(camera)) {
+ model.addElement(camera);
+ }
+ }
+ }
+ if (App.hasArgument("cam")) {
+ String camera = App.getArgumentValue("cam");
+ if (model.getIndexOf(camera) < 0) {
+ if (isVisible(camera)) {
+ model.addElement(camera);
+ }
+ }
+ }
+ model.addElement("");
+
+ return model;
+ }
+
+ PipelineServer newServer() throws IOException {
+ if (serverUrl != null) {
+ System.out.println("Connecting to server: " + serverUrl);
+ server = new PipelineServer(CAMERA_DEVICE_NAME, serverUrl);
+ } else {
+ System.out.println("Connecting to server");
+ server = new PipelineServer(CAMERA_DEVICE_NAME);
+ }
+ updateButtons();
+ return server;
+ }
+
+ boolean updatingCameraSelection;
+
+ void setComboCameraSelection(Object selection) {
+ updatingCameraSelection = true;
+ try {
+ comboCameras.setSelectedItem(selection);
+ } finally {
+ updatingCameraSelection = false;
+ }
+ }
+
+ void setComboTypeSelection(Object selection) {
+ updatingCameraSelection = true;
+ try {
+ comboType.setSelectedItem(selection);
+ } finally {
+ updatingCameraSelection = false;
+ }
+ }
+ boolean usingServer;
+
+ void updateCameraList() {
+ try {
+ String selected = (String) comboCameras.getSelectedItem();
+ comboCameras.setModel(getCameraList(usingServer));
+ if (selected != null) {
+ if (((DefaultComboBoxModel) comboCameras.getModel()).getIndexOf(camera) < 0) {
+ setComboCameraSelection(selected);
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ } finally {
+ updateButtons();
+ }
+ }
+
+ final Object lockOverlays = new Object();
+
+ void manageFit(BufferedImage bi, Data data) {
+ Overlay[][] fo = null;
+ if ((showFit || showProfile)) {
+ try {
+ fo = getFitOverlays(data);
+ } catch (Exception ex) {
+ System.err.println(ex);
+ }
+ }
+ synchronized (lockOverlays) {
+ fo = (fo == null) ? new Overlay[][]{null, null} : fo;
+ renderer.updateOverlays(fo[0], profileOv);
+ profileOv = fo[0];
+ renderer.updateOverlays(fo[1], fitOv);
+ fitOv = fo[1];
+ }
+ }
+
+ void manageUserOverlays(BufferedImage bi, Data data) {
+ Overlay[] fo = (bi == null) ? null : getUserOverlays(data);
+ synchronized (lockOverlays) {
+ renderer.updateOverlays(fo, userOv);
+ userOv = fo;
+ }
+ }
+
+ void updateDialogTitle() {
+ if (App.isDetached()) {
+ getTopLevel().setTitle(cameraName == null ? "ScreenPanel" : cameraName);
+ }
+ }
+
+ void manageTitleOverlay() {
+ Overlay to = null;
+ if ((buttonTitle.isSelected()) && (cameraName != null)) {
+ Font font = new Font("Arial", Font.PLAIN, 28);
+ to = new Text(renderer.getPenErrorText(), cameraName, font, new Point(-SwingUtils.getTextSize(cameraName, renderer.getGraphics().getFontMetrics(font)).width - 14, 26));
+ to.setFixed(true);
+ to.setAnchor(Overlay.ANCHOR_VIEWPORT_OR_IMAGE_TOP_RIGHT);
+ }
+
+ synchronized (lockOverlays) {
+ renderer.updateOverlays(to, titleOv);
+ titleOv = to;
+ }
+ }
+
+ @Override
+ public void onStateChange(State state, State former) {
+
+ }
+
+ @Override
+ public void onExecutedFile(String fileName, Object result) {
+ }
+
+ //Callback to perform update - in event thread
+ @Override
+ protected void doUpdate() {
+ }
+
+ Thread devicesInitTask;
+
+ void setCamera(String cameraName) throws IOException, InterruptedException {
+ System.out.println("Initializing: " + cameraName);
+ parseUserOverlays();
+ errorOverlay = null;
+ lastMarkerPos = null;
+ lastFrame = null;
+ lastPipelinePars = null;
+
+ if (dataTableDialog != null) {
+ dataTableDialog.dispose();
+ dataTableDialog = null;
+ }
+ dataTableModel = null;
+
+ if (calibrationDialolg != null) {
+ calibrationDialolg.dispose();
+ calibrationDialolg = null;
+ }
+
+ boolean was_server = false;
+ if (camera != null) {
+ saveCameraState();
+ //camera.removeAllListeners();
+ was_server = (server != null);
+ camera.close();
+ camera = null;
+ server = null;
+ }
+ updateButtons();
+ instanceName = null;
+ renderer.setDevice(null);
+ renderer.setShowReticle(false);
+ renderer.removeOverlays(fitOv);
+ renderer.removeOverlays(profileOv);
+ renderer.removeOverlays(userOv);
+ renderer.clear();
+ renderer.resetZoom();
+
+ boolean changed = !String.valueOf(cameraName).equals(this.cameraName);
+ this.cameraName = cameraName;
+
+ if (changed || buttonDirect.isSelected()) {
+ spinnerThreshold.setVisible(false);
+ checkThreshold.setEnabled(false);
+ checkRotation.setEnabled(false);
+ checkAveraging.setEnabled(false);
+ checkGoodRegion.setEnabled(false);
+ setGoodRegionOptionsVisible(false);
+ setSlicingOptionsVisible(false);
+ setRotationOptionsVisible(false);
+ setAveragingOptionsVisible(false);
+ }
+ synchronized (imageBuffer) {
+ currentFrame = null;
+ imageBuffer.clear();
+ }
+ if (changed) {
+ checkBackground.setEnabled(false);
+ if ((devicesInitTask != null) && (devicesInitTask.isAlive())) {
+ devicesInitTask.interrupt();
+ }
+ if (screen != null) {
+ screen.close();
+ screen = null;
+ }
+ if (filter != null) {
+ filter.close();
+ filter = null;
+ }
+ if (renderer.isPaused()) {
+ renderer.resume();
+ removePauseOverlay();
+ pauseSelection.setVisible(false);
+ panelCameraSelection.setVisible(true);
+ }
+ }
+ manageTitleOverlay();
+ updateDialogTitle();
+
+ if (cameraName == null) {
+ return;
+ }
+
+ System.out.println("Setting camera: " + cameraName + " [" + (buttonServer.isSelected() ? "server" : "direct") + "]");
+ try {
+ if (buttonServer.isSelected()) {
+ camera = newServer();
+ camera.getConfig().flipHorizontally = false;
+ camera.getConfig().flipVertically = false;
+ camera.getConfig().rotation = 0.0;
+ camera.getConfig().roiX = 0;
+ camera.getConfig().roiY = 0;
+ camera.getConfig().roiWidth = -1;
+ camera.getConfig().roiHeight = -1;
+ } else {
+ //camera = new SfCamera(CAMERA_DEVICE_NAME, cameraName);
+ camera = (ColormapSource) getContext().getClassByName("SfCamera").getConstructor(new Class[]{String.class, String.class}).newInstance(new Object[]{CAMERA_DEVICE_NAME, cameraName});
+ }
+ camera.initialize();
+ camera.assertInitialized();
+ System.out.println("Camera initialization OK");
+ loadCameraState();
+ if (server != null) {
+ //server.start(cameraName, false);
+ String pipelineName = cameraName + pipelineSuffix;
+ instanceName = cameraName + pipelineSuffix + "1";
+ if (!server.getPipelines().contains(pipelineName)) {
+ System.out.println("Creating pipeline: " + pipelineName);
+ HashMap config = new HashMap<>();
+ config.put("camera_name", cameraName);
+ //server.createFromConfig(config, pipelineName);
+ server.savePipelineConfig(pipelineName, config);
+ }
+ server.start(pipelineName, instanceName);
+
+ updatePipelineControls();
+ checkThreshold.setEnabled(true);
+ checkRotation.setEnabled(true);
+ checkAveraging.setEnabled(true);
+ checkGoodRegion.setEnabled(true);
+ } else {
+ checkThreshold.setSelected(false);
+ checkRotation.setSelected(false);
+ checkAveraging.setSelected(false);
+ checkGoodRegion.setSelected(false);
+ if (polling <= 0) {
+ camera.setMonitored(true);
+ } else {
+ camera.setPolling(polling);
+ }
+ camera.setBackgroundEnabled(checkBackground.isSelected());
+ }
+ updateButtons();
+ camera.getConfig().save();
+
+ //if (Math.abs(integration) > 1) {
+ // renderer.setDevice(new ImageIntegrator(integration));
+ //} else {
+ renderer.setDevice(camera);
+ //}
+
+ renderer.setAutoScroll(true);
+ //renderer.setMarker(marker);
+ clearMarker();
+ imageSize = null;
+
+ camera.addListener(new ImageListener() {
+ @Override
+ public void onImage(Object o, BufferedImage bi, Data data) {
+ if (bi != null) {
+ if ((imageSize == null) || imageSize.width != bi.getWidth() || imageSize.height != bi.getHeight()) {
+ SwingUtilities.invokeLater(new Runnable() {
+ @Override
+ public void run() {
+ if ((renderer.getMode() == RendererMode.Zoom) || (renderer.getMode() == RendererMode.Fixed)) {
+ centralizeRenderer();
+ }
+ checkReticle();
+ }
+ });
+ imageSize = new Dimension(bi.getWidth(), bi.getHeight());
+ }
+ renderer.setProfileSize(Math.min(bi.getWidth(), bi.getHeight()));
+ }
+ //renderer.setCalibration(camera.getCalibration());
+ if (!renderer.isPaused()) {
+ if (data != null) {
+ synchronized (imageBuffer) {
+ currentFrame = new Frame(data);
+ if (imageBufferLenght >= 1) {
+ imageBuffer.add(currentFrame);
+ if (imageBuffer.size() > imageBufferLenght) {
+ imageBuffer.remove(0);
+ setBufferFull(true);
+ } else {
+ setBufferFull(false);
+ }
+ } else {
+ setBufferFull(true);
+ }
+ //Update data
+ if (!renderer.isPaused()) {
+ updateStreamData();
+ }
+ updateMarker();
+ }
+ }
+ manageFit(bi, data);
+ manageUserOverlays(bi, data);
+ }
+ //updateImageData();
+ }
+
+ @Override
+ public void onError(Object o, Exception ex) {
+ //System.err.println(ex);
+ }
+ });
+
+ } catch (Exception ex) {
+ showException(ex);
+ renderer.clearOverlays();
+ updatePipelineControls();
+ if (renderer.getDevice() == null) {
+ //renderer.setZoom(1.0);
+ //renderer.setMode(RendererMode.Zoom);
+ errorOverlay = new Text(renderer.getPenErrorText(), ex.toString(), new Font("Verdana", Font.PLAIN, 12), new Point(20, 20));
+ errorOverlay.setFixed(true);
+ errorOverlay.setAnchor(Overlay.ANCHOR_VIEWPORT_TOP_LEFT);
+ renderer.addOverlay(errorOverlay);
+ }
+ } finally {
+ //checkReticle();
+ onTimer();
+ }
+ onChangeColormap(null);
+ checkBackground.setEnabled(true);
+ if (changed) {
+ boolean electrons = getCameraType(cameraName).equals(ELECTRONS_TYPE);
+ comboScreen.setModel(new DefaultComboBoxModel());
+ comboScreen.setEnabled(false);
+ comboFilter.setModel(new DefaultComboBoxModel());
+ comboFilter.setEnabled(false);
+ panelFilter.setVisible(electrons);
+ panelScreen.setVisible(electrons);
+ if (electrons) {
+ //Parallelizing initialization
+ devicesInitTask = new Thread(() -> {
+ try {
+ if (cameraName.contains("DSRM")) {
+ screen = new DiscretePositioner("CurrentScreen", cameraName + ":POSITION_SP", cameraName + ":POSITION");
+ } else {
+ screen = new DiscretePositioner("CurrentScreen", cameraName + ":SET_SCREEN1_POS", cameraName + ":GET_SCREEN1_POS");
+ }
+ screen.setMonitored(true);
+ screen.initialize();
+ DefaultComboBoxModel model = new DefaultComboBoxModel();
+ for (String pos : screen.getPositions()) {
+ model.addElement(pos);
+ }
+ comboScreen.setModel(model);
+ comboScreen.setSelectedItem(screen.read());
+
+ } catch (Exception ex) {
+ comboScreen.setModel(new DefaultComboBoxModel());
+ System.err.println(ex.getMessage());
+ screen = null;
+ }
+ comboScreen.setEnabled(screen != null);
+ valueScreen.setDevice(screen);
+
+ try {
+ filter = new DiscretePositioner("CurrentFilter", cameraName + ":SET_FILTER", cameraName + ":GET_FILTER");
+ filter.setMonitored(true);
+ filter.initialize();
+ DefaultComboBoxModel model = new DefaultComboBoxModel();
+ for (String pos : filter.getPositions()) {
+ model.addElement(pos);
+ }
+ comboFilter.setModel(model);
+ comboFilter.setSelectedItem(filter.read());
+ } catch (Exception ex) {
+ System.err.println(ex.getMessage());
+ filter = null;
+ }
+ comboFilter.setEnabled(filter != null);
+ valueFilter.setDevice(filter);
+ });
+ devicesInitTask.start();
+ }
+ }
+ }
+ /*
+ class ImageIntegrator extends ColormapSource {
+
+ ImageIntegrator(int num) {
+ super("Image Averager", camera.getConfig());
+ boolean continuous = (num < 0);
+ final int numImages = Math.abs(num);
+
+ camera.addListener(new ImageListener() {
+ final ArrayList buffer = new ArrayList();
+ Data integration = null;
+
+ @Override
+ public void onImage(Object o, BufferedImage bi, Data data) {
+ try {
+ if (continuous) {
+ buffer.add(data);
+ if (buffer.size() >= numImages) {
+ for (Data d : buffer) {
+ process(d);
+ }
+ }
+ } else {
+ buffer.add(null); //Just to count
+ process(data);
+ }
+ } catch (Exception ex) {
+ buffer.clear();
+ integration = null;
+ ImageIntegrator.this.pushData(null);
+ ex.printStackTrace();
+ return;
+ }
+ if (buffer.size() >= numImages) {
+ if (continuous) {
+ buffer.remove(0);
+ } else {
+ buffer.clear();
+ }
+ if (integration != null) {
+ //integration.div(numImages);
+ ImageIntegrator.this.pushData(integration);
+ }
+ integration = null;
+ }
+ }
+
+ void process(Data data) {
+ if (integration == null) {
+ integration = new Data(data);
+ } else {
+ integration.sum(data);
+ }
+ }
+
+ @Override
+ public void onError(Object origin, Exception ex) {
+ }
+ });
+
+ }
+ }
+ */
+
+ boolean bufferFull = true;
+
+ void setBufferFull(boolean value) {
+ if (value != bufferFull) {
+ SwingUtilities.invokeLater(() -> {
+ buttonPause.setBackground(value ? buttonSave.getBackground() : buttonSave.getBackground().brighter());
+ });
+ bufferFull = value;
+ }
+ }
+
+ volatile Dimension imageSize;
+
+ void checkReticle() {
+ if ((renderer.getDevice() != null) && (camera != null) && (camera.getConfig().isCalibrated()) && buttonReticle.isSelected()) {
+ //renderer.setCalibration(camera.getCalibration());
+ renderer.configureReticle(new Dimension(800, 800), 200);
+ renderer.setShowReticle(true);
+ } else {
+ //renderer.setCalibration(null);
+ renderer.setShowReticle(false);
+ }
+ renderer.refresh();
+ }
+
+ void checkMarker(Point p) throws IOException {
+ if (camera != null) {
+ if (buttonMarker.isSelected()) {
+ Dimension d = renderer.getImageSize();
+ if (p == null) {
+ p = (d == null) ? new Point(renderer.getWidth() / 2, renderer.getHeight() / 2) : new Point(d.width / 2, d.height / 2);
+ }
+ Overlay ov = null;
+ marker = new Overlays.Crosshairs(renderer.getPenMarker(), p, new Dimension(100, 100));
+ marker.setMovable(true);
+ marker.setPassive(false);
+ } else {
+ marker = null;
+ }
+ renderer.setMarker(marker);
+ onMarkerChanged();
+ }
+ }
+
+ Point lastMarkerPos;
+
+ void onMarkerChanged() throws IOException {
+ lastMarkerPos = getStreamMarkerPos();
+ if (marker == null) {
+ setInstanceConfigValue("Marker", null);
+ } else {
+ setInstanceConfigValue("Marker", new int[]{marker.getPosition().x, marker.getPosition().y});
+ }
+ }
+
+ void updateMarker() {
+ try {
+ if (server != null) {
+ Point p = getStreamMarkerPos();
+ if (p != null) {
+ //To prevent a local change being overriden by a message having the old settings.
+ //TODO: This is not bullet-proof, as one can have 2 changes between 2 frames...
+ if (!p.equals(lastMarkerPos)) {
+ if (p.x == Integer.MIN_VALUE) {
+ if (buttonMarker.isSelected()) {
+ buttonMarker.setSelected(false);
+ checkMarker(null);
+ }
+ } else {
+ if (!buttonMarker.isSelected()) {
+ buttonMarker.setSelected(true);
+ checkMarker(p);
+ } else {
+ if (!p.equals(marker.getPosition())) {
+ marker.setPosition(p);
+ }
+ }
+ }
+ }
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+
+ Point getStreamMarkerPos() throws IOException {
+ //System.out.println(server.getInstanceConfig().get("Marker"));
+ Map pars = server.getProcessingParameters();
+ if (pars != null) {
+ List markerPosition = (List) pars.get("Marker");
+ if (markerPosition != null) {
+ return new Point((Integer) markerPosition.get(0), (Integer) markerPosition.get(1));
+ }
+ return new Point(Integer.MIN_VALUE, Integer.MIN_VALUE);
+ }
+ return null;
+ }
+
+ void clearMarker() {
+ marker = null;
+ renderer.setMarker(marker);
+ }
+
+ void setInstanceConfigValue(String name, Object value) throws IOException {
+ if (server != null) {
+ Map map = server.getInstanceConfig();
+ map.put(name, value);
+ server.setInstanceConfig(map);
+ }
+ }
+
+ void updateZoom() {
+ try {
+ buttonZoomStretch.setSelected(renderer.getMode() == RendererMode.Stretch);
+ buttonZoomFit.setSelected(renderer.getMode() == RendererMode.Fit);
+ if (renderer.getMode() == RendererMode.Fixed) {
+ buttonZoomNormal.setSelected(true);
+ } else if (renderer.getMode() == RendererMode.Zoom) {
+ if (renderer.getZoom() == 1) {
+ buttonZoomNormal.setSelected(true);
+ } else if (renderer.getZoom() == 0.5) {
+ buttonZoom05.setSelected(true);
+ } else if (renderer.getZoom() == 0.25) {
+ buttonZoom025.setSelected(true);
+ } else if (renderer.getZoom() == 2.0) {
+ buttonZoom2.setSelected(true);
+ } else {
+ buttonGroup1.clearSelection();
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+
+ boolean updatingColormap;
+
+ void updateColormap() {
+ updatingColormap = true;
+ try {
+ if ((camera != null) && (camera instanceof ColormapSource)) {
+ ColormapSourceConfig config = ((ColormapSource) camera).getConfig();
+ comboColormap.setSelectedItem(config.colormap);
+ if (config.isDefaultColormap()) {
+ buttonFullRange.setSelected(true);
+ } else if (config.colormapAutomatic) {
+ buttonAutomatic.setSelected(true);
+ } else {
+ buttonManual.setSelected(true);
+ }
+ btFixColormapRange.setVisible(buttonAutomatic.isSelected());
+ spinnerMin.setEnabled(buttonManual.isSelected());
+ spinnerMax.setEnabled(buttonManual.isSelected());
+ if (!Double.isNaN(config.colormapMin)) {
+ spinnerMin.setValue(Math.min(Math.max((int) config.colormapMin, 0), 65535));
+ }
+ if (!Double.isNaN(config.colormapMax)) {
+ spinnerMax.setValue(Math.min(Math.max((int) config.colormapMax, 0), 65535));
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ updatingColormap = false;
+ }
+
+ void updatePipelineProperties() {
+ goodRegion = checkGoodRegion.isSelected();
+ spinnerThreshold.setVisible(checkThreshold.isSelected());
+ setGoodRegionOptionsVisible(goodRegion);
+ slicing = goodRegion && checkSlicing.isSelected();
+ setSlicingOptionsVisible(slicing);
+ updatingServerControls = false;
+ boolean rotation = checkRotation.isSelected();
+ setRotationOptionsVisible(rotation);
+ boolean averaging = checkAveraging.isSelected();
+ setAveragingOptionsVisible(averaging);
+ }
+
+ boolean updatingServerControls;
+
+ void updatePipelineControls() {
+ if (server != null) {
+ updatingServerControls = true;
+ if (server.isStarted()) {
+ try {
+ checkBackground.setSelected(server.getBackgroundSubtraction());
+ Double threshold = (server.getThreshold());
+ checkThreshold.setSelected(threshold != null);
+ spinnerThreshold.setValue((threshold == null) ? 0 : threshold);
+ Map gr = (server.getGoodRegion());
+ checkGoodRegion.setSelected(gr != null);
+ if (gr != null) {
+ spinnerGrThreshold.setValue(((Number) gr.get("threshold")).doubleValue());
+ spinnerGrScale.setValue(((Number) gr.get("gfscale")).doubleValue());
+ }
+ Map rotation = server.getRotation();
+ checkRotation.setSelected(rotation != null);
+ if (rotation!=null){
+ spinnerRotationAngle.setValue(((Number) rotation.get("angle")).doubleValue());
+ spinnerRotationOrder.setValue(((Number) rotation.get("order")).intValue());
+ String mode = (String) rotation.get("mode");
+ try{
+ spinnerRotationConstant.setValue(Double.valueOf(mode));
+ spinnerRotationMode.setValue("constant");
+ } catch (Exception ex){
+ spinnerRotationConstant.setValue(0);
+ spinnerRotationMode.setValue(mode);
+ }
+ }
+
+ Number averaging = (Number) server.getInstanceConfig().get("averaging");
+ checkAveraging.setSelected(averaging != null);
+ if (averaging!=null){
+ spinnerAvFrames.setValue(Math.abs(averaging.intValue()));
+ spinnerAvMode.setValue(averaging.intValue()<0 ? "window" : "single");
+ }
+
+
+ Map slicing = (server.getSlicing());
+ checkSlicing.setSelected(slicing != null);
+ if (slicing != null) {
+ spinnerSlNumber.setValue(((Number) slicing.get("number_of_slices")).intValue());
+ spinnerSlScale.setValue(((Number) slicing.get("scale")).doubleValue());
+ spinnerSlOrientation.setValue((String) slicing.get("orientation"));
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ updatePipelineProperties();
+ }
+ }
+
+ boolean changedPipelinePars(Map pars1, Map pars2) {
+ String[] keys = new String[]{"image_background_enable", "image_threshold", "image_good_region",
+ "threshold", "gfscale", "image_slices", "number_of_slices", "scale", "orientation"};
+ for (String key : keys) {
+ Object o1 = pars1.get(key);
+ Object o2 = pars2.get(key);
+ if (o1 == null) {
+ if (o2 != null) {
+ return true;
+ }
+ } else if (!o1.equals(o2)) {
+ return true;
+ }
+ }
+ return false;
+ }
+
+ void updatePipelineControls(Map pars) {
+ if (pars != null) {
+ updatingServerControls = true;
+ try {
+ boolean background = (boolean) pars.get("image_background_enable");
+ checkBackground.setSelected(background);
+ Double threshold = (Double) (pars.get("image_threshold"));
+ checkThreshold.setSelected(threshold != null);
+ spinnerThreshold.setValue((threshold == null) ? 0 : threshold);
+ Map gr = (Map) pars.get("image_good_region");
+ checkGoodRegion.setSelected(gr != null);
+ if (gr != null) {
+ Double value = ((Number) gr.get("threshold")).doubleValue();
+ spinnerGrThreshold.setValue(value);
+ Double scale = ((Number) gr.get("gfscale")).doubleValue();
+ spinnerGrScale.setValue(scale);
+ }
+ Map slicing = (Map) (pars.get("image_slices"));
+ checkSlicing.setSelected(slicing != null);
+ if (slicing != null) {
+ int slices = ((Number) slicing.get("number_of_slices")).intValue();
+ spinnerSlNumber.setValue(slices);
+ double scale = ((Number) slicing.get("scale")).doubleValue();
+ spinnerSlScale.setValue(scale);
+ String orientation = (String) slicing.get("orientation");
+ spinnerSlOrientation.setValue(orientation);
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ updatePipelineProperties();
+ }
+ }
+
+ void setGoodRegionOptionsVisible(boolean visible) {
+ spinnerGrThreshold.setVisible(visible);
+ labelGrThreshold.setVisible(visible);
+ spinnerGrScale.setVisible(visible);
+ labelGrScale.setVisible(visible);
+ panelSlicing.setVisible(visible);
+ }
+
+ void setSlicingOptionsVisible(boolean visible) {
+ spinnerSlNumber.setVisible(visible);
+ labelSlNumber.setVisible(visible);
+ spinnerSlScale.setVisible(visible);
+ labelSlScale.setVisible(visible);
+ spinnerSlOrientation.setVisible(visible);
+ labelSlOrientation.setVisible(visible);
+ }
+
+ void setAveragingOptionsVisible(boolean visible) {
+ labelAvMode.setVisible(visible);
+ labelAvFrames.setVisible(visible);
+ spinnerAvMode.setVisible(visible);
+ spinnerAvFrames.setVisible(visible);
+ }
+
+ void setRotationOptionsVisible(boolean visible) {
+ labelAngle.setVisible(visible);
+ labelOrder.setVisible(visible);
+ labelMode.setVisible(visible);
+ labelConstant.setVisible(visible);
+ spinnerRotationAngle.setVisible(visible);
+ spinnerRotationOrder.setVisible(visible);
+ spinnerRotationMode.setVisible(visible);
+ spinnerRotationConstant.setVisible(visible);
+ }
+
+ boolean isCameraStopped() {
+ if ((server != null) && !server.isStarted()) {
+ return true;
+ }
+ return ((camera == null) || camera.isClosed());
+ }
+
+ boolean updatingButtons;
+
+ void updateButtons() {
+ updatingButtons = true;
+ try {
+ boolean active = !isCameraStopped();//(camera != null);
+ buttonSave.setEnabled(active);
+ buttonGrabBackground.setEnabled(active);
+ buttonMarker.setEnabled(active);
+ buttonProfile.setEnabled(active);
+ buttonFit.setEnabled(active);
+ buttonReticle.setEnabled(active && camera.getConfig().isCalibrated());
+ buttonStreamData.setEnabled(active && (server != null));
+ buttonPause.setEnabled(active);
+
+ if (renderer.isPaused() != buttonPause.isSelected()) {
+ buttonPause.setSelected(renderer.isPaused());
+ buttonPauseActionPerformed(null);
+ }
+ if (renderer.getShowReticle() != buttonReticle.isSelected()) {
+ //buttonReticle.setSelected(renderer.getShowReticle());
+ }
+ if ((renderer.getMarker() == null) && buttonMarker.isSelected()) {
+ buttonMarker.setSelected(false);
+ }
+ buttonSave.setSelected(renderer.isSnapshotDialogVisible());
+
+ } finally {
+ updatingButtons = false;
+ }
+ }
+
+ Frame lastFrame = null;
+ Map lastPipelinePars = null;
+
+ @Override
+ protected void onTimer() {
+ for (Device dev : new Device[]{screen, filter}) {
+ if (dev != null) {
+ dev.request();
+ }
+ }
+
+ textState.setText((camera == null) ? "" : camera.getState().toString());
+ if (App.hasArgument("s")) {
+ try {
+ ((Source) getDevice("image")).initialize();
+ } catch (IOException ex) {
+ Logger.getLogger(getClass().getName()).log(Level.SEVERE, null, ex);
+ } catch (InterruptedException ex) {
+ Logger.getLogger(getClass().getName()).log(Level.SEVERE, null, ex);
+ }
+ }
+ updateZoom();
+ updateColormap();
+ updateButtons();
+ checkHistogram.setSelected((histogramDialog != null) && (histogramDialog.isShowing()));
+ buttonScale.setSelected(renderer.getShowColormapScale());
+ try {
+ Frame frame = getCurrentFrame();
+ if (frame != lastFrame) {
+ lastFrame = frame;
+ if (frame != null) {
+ Map pars = getProcessingParameters(frame.cache);
+ if ((lastPipelinePars == null) || changedPipelinePars(pars, lastPipelinePars)) {
+ //System.out.println("Update pipeline: " + pars);
+ lastPipelinePars = pars;
+ updatePipelineControls(pars);
+ }
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+
+ Pen penFit = new Pen(new Color(192, 105, 0), 0);
+ Pen penCross = new Pen(new Color(192, 105, 0), 0);
+ Pen penSlices = new Pen(Color.CYAN.darker(), 1);
+
+ Frame getCurrentFrame() {
+ if ((imageBufferLenght > 1) && (renderer.isPaused())) {
+ int index = ((int) pauseSelection.getValue()) - 1;
+ synchronized (imageBuffer) {
+ return (index < imageBuffer.size()) ? imageBuffer.get(index) : null;
+ }
+ }
+ return currentFrame;
+ }
+
+ Frame getFrame(Data data) {
+ synchronized (imageBuffer) {
+ for (Frame f : imageBuffer) {
+ if (f.data == data) {
+ return f;
+ }
+ }
+ }
+ return null;
+ }
+
+ void setImageBufferSize(int size) {
+ if (renderer.isPaused()) {
+ throw new RuntimeException("Cannot change buffer size whn paused");
+ }
+ synchronized (imageBuffer) {
+ imageBufferLenght = size;
+ imageBuffer.clear();
+ }
+
+ }
+
+ Overlay[][] getFitOverlays(Data data) {
+ Overlays.Polyline hgaussian = null;
+ Overlays.Polyline vgaussian = null;
+ Overlays.Polyline hprofile = null;
+ Overlays.Polyline vprofile = null;
+ Double xMean = null, xSigma = null, xNorm = null, xCom = null, xRms = null;
+ Double yMean = null, ySigma = null, yNorm = null, yCom = null, yRms = null;
+ double[] pX = null, pY = null, gX = null, gY = null;
+ PointDouble[] sliceCenters = null;
+ if (data != null) {
+ int height = data.getHeight();
+ int width = data.getWidth();
+ int profileSize = renderer.getProfileSize();
+ ImageData id = null;
+ if ((useServerStats) && (server != null)) {
+ try {
+ id = getFrame(data);
+ if (id == null) {
+ return null;
+ }
+ xMean = id.x_fit_mean;
+ xSigma = id.x_fit_standard_deviation;
+ yMean = id.y_fit_mean;
+ ySigma = id.y_fit_standard_deviation;
+ gX = id.x_fit_gauss_function;
+ gY = id.y_fit_gauss_function;
+ pX = id.x_profile;
+ pY = id.y_profile;
+ xCom = id.x_center_of_mass;
+ xRms = id.x_rms;
+ yCom = id.y_center_of_mass;
+ yRms = id.y_rms;
+ sliceCenters = id.sliceCenters;
+
+ profileSize /= 4;
+ if (pX != null) {
+ int[] xp = Arr.indexesInt(pX.length);
+ int[] xg = xp;
+ int[] yp = new int[pX.length];
+ int[] yg = new int[pX.length];
+
+ List l = Arrays.asList((Double[]) Convert.toWrapperArray(pX));
+ double minProfile = Collections.min(l);
+ double maxProfile = Collections.max(l);
+ double rangeProfile = maxProfile - minProfile;
+ double minGauss = minProfile;
+ double rangeGauss = rangeProfile;
+ //If not good region, range of profile and fit are similar so save this calcultion
+ if (goodRegion && id.gr_size_x > 0) {
+ l = Arrays.asList((Double[]) Convert.toWrapperArray(Arrays.copyOfRange(gX, id.gr_pos_x, id.gr_pos_x + id.gr_size_x)));
+ minGauss = Collections.min(l);
+ rangeGauss = Collections.max(l) - minGauss;
+ }
+
+ for (int i = 0; i < xp.length; i++) {
+ if (gX != null) {
+ yg[i] = (int) (height - 1 - (((gX[i] - minGauss) / rangeGauss) * profileSize));
+ }
+ yp[i] = (int) (height - 1 - (((pX[i] - minProfile) / rangeProfile) * profileSize));
+ }
+
+ if (goodRegion && id.gr_size_x > 0) {
+ xg = Arrays.copyOfRange(xg, id.gr_pos_x, id.gr_pos_x + id.gr_size_x);
+ yg = Arrays.copyOfRange(yg, id.gr_pos_x, id.gr_pos_x + id.gr_size_x);
+ }
+
+ vgaussian = new Overlays.Polyline(penFit, xg, yg);
+ vprofile = new Overlays.Polyline(renderer.getPenProfile(), xp, yp);
+ }
+
+ if (pY != null) {
+ int[] xp = new int[pY.length];
+ int[] xg = new int[pY.length];
+ int[] yp = Arr.indexesInt(pY.length);
+ int[] yg = yp;
+
+ List l = Arrays.asList((Double[]) Convert.toWrapperArray(pY));
+ double minProfile = Collections.min(l);
+ double maxProfile = Collections.max(l);
+ double rangeProfile = maxProfile - minProfile;
+ double minGauss = minProfile;
+ double rangeGauss = rangeProfile;
+ //If not good region, range of profile and fit are similar so save this calcultion
+ if (goodRegion && id.gr_size_y > 0) {
+ l = Arrays.asList((Double[]) Convert.toWrapperArray(Arrays.copyOfRange(gY, id.gr_pos_y, id.gr_pos_y + id.gr_size_y)));
+ minGauss = Collections.min(l);
+ rangeGauss = Collections.max(l) - minGauss;
+ }
+
+ for (int i = 0; i < xp.length; i++) {
+ if (gY != null) {
+ xg[i] = (int) (((gY[i] - minGauss) / rangeGauss) * profileSize);
+ }
+ xp[i] = (int) (((pY[i] - minProfile) / rangeProfile) * profileSize);
+ }
+
+ if (goodRegion && id.gr_size_y > 0) {
+ xg = Arrays.copyOfRange(xg, id.gr_pos_y, id.gr_pos_y + id.gr_size_y);
+ yg = Arrays.copyOfRange(yg, id.gr_pos_y, id.gr_pos_y + id.gr_size_y);
+ }
+ hgaussian = new Overlays.Polyline(penFit, xg, yg);
+ hprofile = new Overlays.Polyline(renderer.getPenProfile(), xp, yp);
+ }
+ } catch (Exception ex) {
+ System.err.println(ex.getMessage());
+ return null;
+ }
+ } else {
+ ArrayProperties properties = data.getProperties();
+ double maxPlot = properties.max;
+ double minPlot = properties.min;
+ double rangePlot = maxPlot - minPlot;
+
+ if (rangePlot <= 0) {
+ return null;
+ }
+ if (renderer.getCalibration() != null) {
+ try {
+ double[] sum = data.integrateVertically(true);
+ double[] saux = new double[sum.length];
+ int[] p = new int[sum.length];
+ double[] x_egu = renderer.getCalibration().getAxisX(sum.length);
+ double[] comRms = getComRms(sum, x_egu);
+ xCom = comRms[0];
+ xRms = comRms[1];
+ int[] x = Arr.indexesInt(sum.length);
+ DescriptiveStatistics stats = new DescriptiveStatistics(sum);
+ double min = stats.getMin();
+ for (int i = 0; i < sum.length; i++) {
+ saux[i] = sum[i] - min;
+ }
+ if (showFit) {
+ double[] gaussian = fitGaussian(saux, x);
+ if (gaussian != null) {
+ if ((gaussian[2] < sum.length * 0.45)
+ && (gaussian[2] > 2)
+ && (gaussian[0] > min * 0.03)) {
+ xNorm = gaussian[0];
+ xMean = gaussian[1];
+ xSigma = gaussian[2];
+ double[] fit = getFitFunction(gaussian, x);
+ int[] y = new int[x.length];
+ for (int i = 0; i < x.length; i++) {
+ y[i] = (int) (height - 1 - ((((fit[i] + min) / height - minPlot) / rangePlot) * profileSize));
+ }
+ vgaussian = new Overlays.Polyline(penFit, x, y);
+ }
+ }
+ }
+ if (showProfile) {
+ for (int i = 0; i < x.length; i++) {
+ p[i] = (int) (height - 1 - (((sum[i] / height - minPlot) / rangePlot) * profileSize));
+ }
+ vprofile = new Overlays.Polyline(renderer.getPenProfile(), x, p);
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+
+ try {
+ double[] sum = data.integrateHorizontally(true);
+ double[] saux = new double[sum.length];
+ int[] p = new int[sum.length];
+ double[] y_egu = renderer.getCalibration().getAxisY(sum.length);
+ double[] comRms = getComRms(sum, y_egu);
+ yCom = comRms[0];
+ yRms = comRms[1];
+ int[] x = Arr.indexesInt(sum.length);
+ DescriptiveStatistics stats = new DescriptiveStatistics(sum);
+ double min = stats.getMin();
+ for (int i = 0; i < sum.length; i++) {
+ saux[i] = sum[i] - min;
+ }
+
+ if (showFit) {
+ double[] gaussian = fitGaussian(saux, x);
+ if (gaussian != null) {
+ //Only aknowledge beam fully inside the image and peak over 3% of min
+ if ((gaussian[2] < sum.length * 0.45)
+ && (gaussian[2] > 2)
+ && (gaussian[0] > min * 0.03)) {
+ yNorm = gaussian[0];
+ yMean = gaussian[1];
+ ySigma = gaussian[2];
+ double[] fit = getFitFunction(gaussian, x);
+
+ int[] y = new int[x.length];
+ for (int i = 0; i < x.length; i++) {
+ y[i] = (int) ((((fit[i] + min) / width - minPlot) / rangePlot) * profileSize);
+ }
+ hgaussian = new Overlays.Polyline(penFit, y, x);
+ }
+ }
+ }
+ if (showProfile) {
+ for (int i = 0; i < x.length; i++) {
+ p[i] = (int) (((sum[i] / width - minPlot) / rangePlot) * profileSize);
+ }
+ hprofile = new Overlays.Polyline(renderer.getPenProfile(), p, x);
+ }
+
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ if (xSigma != null) {
+ xSigma *= renderer.getCalibration().getScaleX();
+ }
+ if (ySigma != null) {
+ ySigma *= renderer.getCalibration().getScaleY();
+ }
+ if (xMean != null) {
+ xMean = data.getX((int) Math.round(xMean));
+ }
+ if (yMean != null) {
+ yMean = data.getY((int) Math.round(yMean));
+ }
+ }
+ }
+ final String units = (renderer.getCalibration() != null) ? "\u00B5m" : "px";
+ final String fmt = "%7.1f" + units;
+ Overlays.Text textCom = null;
+ Overlay[] pOv = null, fOv = null;
+ Font fontInfoText = new Font(Font.MONOSPACED, 0, 14);
+ Point textPosition = new Point(12, 20);
+ if (showProfile) {
+ if ((xCom != null) && (yCom != null)) {
+ String text = String.format("com x: m=" + fmt + " \u03C3=" + fmt + "\ncom y: m=" + fmt + " \u03C3=" + fmt, xCom, xRms, yCom, yRms);
+ textCom = new Overlays.Text(renderer.getPenProfile(), text, fontInfoText, textPosition);
+ textCom.setFixed(true);
+ textCom.setAnchor(Overlay.ANCHOR_VIEWPORT_TOP_LEFT);
+ }
+ pOv = new Overlay[]{hprofile, vprofile, textCom};
+ textPosition = new Point(textPosition.x, textPosition.y + 34);
+ }
+ if (showFit) {
+ Overlays.Crosshairs cross = null;
+ Overlays.Text textFit = null;
+ if ((xMean != null) && (yMean != null)) {
+ String text = String.format("fit x: m=" + fmt + " \u03C3=" + fmt + "\nfit y: m=" + fmt + " \u03C3=" + fmt, xMean, xSigma, yMean, ySigma);
+ textFit = new Overlays.Text(penFit, text, fontInfoText, textPosition);
+ textFit.setFixed(true);
+ textFit.setAnchor(Overlay.ANCHOR_VIEWPORT_TOP_LEFT);
+ Point center = new Point(xMean.intValue(), yMean.intValue());
+ if (renderer.getCalibration() != null) {
+ center = renderer.getCalibration().convertToImagePosition(new PointDouble(xMean, yMean));
+ xSigma /= renderer.getCalibration().getScaleX();
+ ySigma /= renderer.getCalibration().getScaleY();
+ }
+ cross = new Overlays.Crosshairs(penCross, center, new Dimension(Math.abs(2 * xSigma.intValue()), 2 * Math.abs(ySigma.intValue())));
+ }
+ textPosition = new Point(textPosition.x, textPosition.y + 34);
+ fOv = new Overlay[]{hgaussian, vgaussian, cross, textFit};
+
+ if (goodRegion && (id != null)) {
+ try {
+ double[] x = id.gr_x_axis;
+ double[] y = id.gr_y_axis;
+ Overlays.Rect goodRegionOv = new Overlays.Rect(new Pen(penFit.getColor(), 0, Pen.LineStyle.dotted));
+ goodRegionOv.setCalibration(renderer.getCalibration());
+ goodRegionOv.setPosition(new Point(id.gr_pos_x, id.gr_pos_y));
+ goodRegionOv.setSize(new Dimension(id.gr_x_axis.length, id.gr_y_axis.length));
+ fOv = Arr.append(fOv, goodRegionOv);
+
+ if (slicing) {
+ if (sliceCenters != null) {
+ for (PointDouble sliceCenter : sliceCenters) {
+ Overlays.Crosshairs center = new Overlays.Crosshairs(penSlices);
+ center.setCalibration(renderer.getCalibration());
+ center.setAbsolutePosition(sliceCenter);
+ center.setSize(new Dimension(10, 10));
+ fOv = Arr.append(fOv, center);
+ }
+ if (sliceCenters.length > 1) {
+ double[] fit = fitPolynomial(sliceCenters, 1);
+ double angle = Math.toDegrees(Math.atan(fit[1]));
+ Overlays.Text text = new Overlays.Text(penSlices, String.format("slice: \u03B8= %5.1fdeg", angle), fontInfoText, textPosition);
+ text.setFixed(true);
+ text.setAnchor(Overlay.ANCHOR_VIEWPORT_TOP_LEFT);
+ fOv = Arr.append(fOv, text);
+ }
+ }
+ }
+ } catch (Exception ex) {
+ }
+ }
+
+ }
+ return new Overlay[][]{pOv, fOv};
+ }
+ return null;
+ }
+
+ class UserOverlay {
+
+ String name;
+ Overlay obj;
+ String[] channels;
+ }
+ ArrayList userOverlayConfig;
+
+ void parseUserOverlays() {
+ Properties userOverlays = new Properties();
+ userOverlayConfig = new ArrayList<>();
+ if (userOverlaysConfigFile != null) {
+ try {
+ try (FileInputStream in = new FileInputStream(getContext().getSetup().expandPath(userOverlaysConfigFile))) {
+ userOverlays.load(in);
+
+ for (String name : userOverlays.stringPropertyNames()) {
+ String val = userOverlays.getProperty(name);
+ try {
+ UserOverlay uo = new UserOverlay();
+ uo.name = name;
+ String type = val.substring(0, val.indexOf("(")).trim();
+ String pars = val.substring(val.indexOf("(") + 1, val.lastIndexOf(")")).trim();
+ String[] tokens = pars.split(",");
+ for (int i = 0; i < tokens.length; i++) {
+ tokens[i] = tokens[i].trim();
+ }
+ Color color = Color.GRAY;
+ try {
+ color = (Color) Color.class.getField(tokens[tokens.length - 1].toUpperCase()).get(null);
+ } catch (Exception ex) {
+ }
+ Pen pen = new Pen(color);
+ try {
+ String[] penTokens = tokens[tokens.length - 1].split(":");
+ color = (Color) Color.class.getField(penTokens[0].toUpperCase()).get(null);
+ int width = Integer.valueOf(penTokens[1]);
+ Pen.LineStyle style = Pen.LineStyle.valueOf(penTokens[2]);
+ pen = new Pen(color, width, style);
+ } catch (Exception ex) {
+ }
+ switch (type) {
+ case "Point":
+ uo.obj = new Overlays.Crosshairs();
+ uo.obj.setSize(new Dimension(Integer.valueOf(tokens[2]), Integer.valueOf(tokens[3])));
+ break;
+ case "Line":
+ uo.obj = new Overlays.Line();
+ break;
+ case "Arrow":
+ uo.obj = new Overlays.Arrow();
+ break;
+ case "Rect":
+ uo.obj = new Overlays.Rect();
+ break;
+ case "Ellipse":
+ uo.obj = new Overlays.Ellipse();
+ break;
+ case "Polyline":
+ uo.obj = new Overlays.Polyline();
+ break;
+ }
+ if (type.equals("Polyline") || type.equals("Point")) {
+ uo.channels = new String[]{tokens[0], tokens[1]};
+ } else {
+ uo.channels = new String[]{tokens[0], tokens[1], tokens[2], tokens[3]};
+ }
+ uo.obj.setPen(pen);
+ userOverlayConfig.add(uo);
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ }
+
+ Overlay[] getUserOverlays(Data data) {
+ ArrayList ret = new ArrayList<>();
+ if (server != null) {
+ ImageData id = getFrame(data);
+ for (UserOverlay uo : userOverlayConfig) {
+ try {
+ Overlay ov = uo.obj;
+ //Overlay ov = (Overlay)uo.cls.newInstance();
+ ov.setCalibration(renderer.getCalibration());
+ boolean valid = false;
+ if (ov instanceof Overlays.Polyline) {
+ double[] x = (uo.channels[0].equals("null")) ? null : id.getDoubleArray(uo.channels[0]);
+ double[] y = (uo.channels[1].equals("null")) ? null : id.getDoubleArray(uo.channels[1]);
+ if ((x != null) || (y != null)) {
+ if (x == null) {
+ x = (renderer.getCalibration() == null) ? Arr.indexesDouble(y.length) : renderer.getCalibration().getAxisX(y.length);
+ }
+ if (y == null) {
+ y = (renderer.getCalibration() == null) ? Arr.indexesDouble(x.length) : renderer.getCalibration().getAxisY(x.length);
+ }
+ ((Overlays.Polyline) ov).updateAbsolute(x, y);
+ valid = true;
+ }
+ } else {
+ Double x = id.getDouble(uo.channels[0]);
+ Double y = id.getDouble(uo.channels[1]);
+ if ((x != null) && (y != null)) {
+ PointDouble position = new PointDouble(x, y);
+ ov.setAbsolutePosition(position);
+ if (!(ov instanceof Overlays.Crosshairs)) {
+ Double x2 = id.getDouble(uo.channels[2]);
+ Double y2 = id.getDouble(uo.channels[3]);
+ if ((x != null) && (y != null)) {
+ DimensionDouble size = new DimensionDouble(x2 - position.x, y2 - position.y);
+ ov.setAbsoluteSize(size);
+ valid = true;
+ }
+ } else {
+ valid = true;
+ }
+ }
+ }
+ if (valid) {
+ ret.add(ov);
+ }
+ } catch (Exception ex) {
+ //ex.printStackTrace();
+ }
+ }
+ }
+ return ret.toArray(new Overlay[0]);
+ }
+
+ double[] getComRms(double[] arr, double[] x) {
+ if (arr != null) {
+ double xmd = 0;
+ double xmd2 = 0;
+ double total = 0;
+ for (int i = 0; i < arr.length; i++) {
+ double v = (arr[i] * x[i]);
+ xmd += v;
+ xmd2 += (v * x[i]);
+ total += arr[i];
+ }
+ if (total > 0) {
+ double com = xmd / total;
+ double com2 = xmd2 / total;
+ double rms = Math.sqrt(Math.abs(com2 - com * com));
+ return new double[]{com, rms};
+ }
+ }
+ return new double[]{Double.NaN, Double.NaN};
+ }
+
+ double[] fitGaussianScript(int[] y, int[] x) {
+ ScriptManager sm = Context.getInstance().getScriptManager();
+ ArrayProperties pY = ArrayProperties.get(y);
+ sm.setVar("y", y);
+ sm.setVar("x", x);
+ InterpreterResult r = sm.eval("r = fit_gaussians(y, x, [" + pY.maxIndex + ",])");
+ if (r.exception != null) {
+ r.exception.printStackTrace();
+ } else {
+ List ret = (List) sm.getVar("r");
+ if ((ret != null) && (ret.size() == 1) && (ret.get(0) instanceof List) && (((List) (ret.get(0))).size() == 3)) {
+ double norm = (Double) ((List) ret.get(0)).get(0);
+ double mean = (Double) ((List) ret.get(0)).get(1);
+ double sigma = (Double) ((List) ret.get(0)).get(2);
+ return new double[]{norm, mean, sigma};
+ }
+ }
+ return null;
+ }
+
+ double[] fitGaussian(double[] y, int[] x) {
+ try {
+ ArrayProperties pY = ArrayProperties.get(y);
+ GaussianCurveFitter fitter = GaussianCurveFitter.create().withStartPoint(new double[]{(pY.max - pY.min) / 2, x[pY.maxIndex], 1.0}).withMaxIterations(1000);
+ ArrayList values = new ArrayList<>();
+ for (int i = 0; i < y.length; i++) {
+ values.add(new WeightedObservedPoint(1.0, x[i], y[i]));
+ }
+ return fitter.fit(values);
+ } catch (Exception ex) {
+ return null;
+ }
+
+ }
+
+ double[] fitPolynomial(PointDouble[] points, int order) {
+ double[] y = new double[points.length];
+ double[] x = new double[points.length];
+ for (int i = 0; i < points.length; i++) {
+ x[i] = points[i].x;
+ y[i] = points[i].y;
+ }
+ return fitPolynomial(y, x, order);
+ }
+
+ double[] fitPolynomial(double[] y, double[] x, int order) {
+ try {
+ ArrayProperties pY = ArrayProperties.get(y);
+ PolynomialCurveFitter fitter = PolynomialCurveFitter.create(order).withMaxIterations(1000);
+ ArrayList values = new ArrayList<>();
+ for (int i = 0; i < y.length; i++) {
+ values.add(new WeightedObservedPoint(1.0, x[i], y[i]));
+ }
+ return fitter.fit(values);
+ } catch (Exception ex) {
+ return null;
+ }
+
+ }
+
+ double[] getFitFunction(double[] pars, int[] x) {
+ double[] fit = new double[x.length];
+ Gaussian g = new Gaussian(pars[0], pars[1], pars[2]);
+ for (int i = 0; i < x.length; i++) {
+ fit[i] = g.value(x[i]);
+ }
+ return fit;
+ }
+
+ void setHistogramVisible(boolean value) {
+ if (value) {
+ if ((histogramDialog == null) || (!histogramDialog.isShowing())) {
+ Histogram histogram = new Histogram(true);
+ histogram.setRenderer(renderer);
+ histogramDialog = SwingUtils.showDialog(SwingUtils.getWindow(renderer), "Histogram", null, histogram);
+ renderer.refresh();
+ }
+ } else {
+ if (histogramDialog != null) {
+ histogramDialog.setVisible(false);
+ histogramDialog = null;
+ }
+ }
+ }
+
+ void setLaserState(int bunch, boolean value) throws Exception {
+ System.out.println("Setting laser state: " + value + " - bunch" + bunch);
+ //Epics.putq("SIN-TIMAST-TMA:Beam-Las-Delay-Sel", value ? 0 : 1);
+ if ((bunch<=0) || (bunch==1)){
+ Epics.putq("SWISSFEL-STATUS:Bunch-1-OnDelay-Sel", value ? 0 : 1);
+ }
+ if ((bunch<=0) || (bunch==2)){
+ Epics.putq("SWISSFEL-STATUS:Bunch-2-OnDelay-Sel", value ? 0 : 1);
+ }
+
+ Epics.putq("SIN-TIMAST-TMA:Beam-Apply-Cmd.PROC", 1);
+ Thread.sleep(3000);
+ }
+
+ boolean getLaserState(int bunch) throws Exception {
+ //return (Epics.get("SIN-TIMAST-TMA:Beam-Las-Delay-Sel", Integer.class) == 0);
+ if (bunch<=0){
+ return getLaserState(1) && getLaserState(2);
+ }
+ if (bunch==2){
+ return (Epics.get("SWISSFEL-STATUS:Bunch-2-OnDelay-Sel", Integer.class) == 0);
+ }
+ return (Epics.get("SWISSFEL-STATUS:Bunch-1-OnDelay-Sel", Integer.class) == 0);
+ }
+
+ void elog(String logbook, String title, String message, String[] attachments) throws Exception {
+ String domain = "";
+ String category = "Info";
+ String entry = "";
+ StringBuffer cmd = new StringBuffer();
+
+ cmd.append("G_CS_ELOG_add -l \"").append(logbook).append("\" ");
+ cmd.append("-a \"Author=ScreenPanel\" ");
+ cmd.append("-a \"Type=pshell\" ");
+ cmd.append("-a \"Entry=").append(entry).append("\" ");
+ cmd.append("-a \"Title=").append(title).append("\" ");
+ cmd.append("-a \"Category=").append(category).append("\" ");
+ cmd.append("-a \"Domain=").append(domain).append("\" ");
+ for (String attachment : attachments) {
+ cmd.append("-f \"").append(attachment).append("\" ");
+ }
+ cmd.append("-n 1 ");
+ cmd.append("\"").append(message).append("\" ");
+ System.out.println(cmd.toString());
+
+ final Process process = Runtime.getRuntime().exec(new String[]{"bash", "-c", cmd.toString()});
+ new Thread(() -> {
+ try {
+ process.waitFor();
+ int bytes = process.getInputStream().available();
+ byte[] arr = new byte[bytes];
+ process.getInputStream().read(arr, 0, bytes);
+ System.out.println(new String(arr));
+ bytes = process.getErrorStream().available();
+ arr = new byte[bytes];
+ process.getErrorStream().read(arr, 0, bytes);
+ System.err.println(new String(arr));
+ } catch (Exception ex) {
+ System.err.println(ex);
+ }
+ }).start();
+ }
+
+ void centralizeRenderer() {
+ Point center = null;
+ Dimension size = renderer.getImageSize();
+ double zoom = (renderer.getMode() == RendererMode.Fixed) ? 1.0 : renderer.getZoom();
+ if (renderer.getCalibration() != null) {
+ center = renderer.getCalibration().getCenter();
+ } else if (size != null) {
+ center = new Point(size.width / 2, size.height / 2);
+ }
+ if (center != null) {
+ Point topleft = new Point(Math.max((int) (center.x - renderer.getWidth() / 2 / zoom), 0),
+ Math.max((int) (center.y - renderer.getHeight() / 2 / zoom), 0));
+ renderer.setViewPosition(topleft);
+ }
+ }
+
+ void updatePause() {
+ int index = ((int) pauseSelection.getValue()) - 1;
+ synchronized (imageBuffer) {
+ if (index < imageBuffer.size()) {
+ Data data = imageBuffer.get(index).data;
+ long pid = imageBuffer.get(index).cache.getPulseId();
+ BufferedImage image = camera.generateImage(data);
+ renderer.setImage(renderer.getOrigin(), image, data);
+
+ String text = "PID: " + pid;
+ if (imagePauseOverlay == null) {
+ Font font = new Font("Verdana", Font.PLAIN, 12);
+ Dimension d = SwingUtils.getTextSize(text, renderer.getFontMetrics(font));
+ imagePauseOverlay = new Text(renderer.getPenErrorText(), "", font, new Point(-20 - d.width, 42));
+ imagePauseOverlay.setFixed(true);
+ imagePauseOverlay.setAnchor(Overlay.ANCHOR_VIEWPORT_OR_IMAGE_TOP_RIGHT);
+ renderer.addOverlay(imagePauseOverlay);
+ }
+ //imagePauseOverlay.update(Chrono.getTimeStr(data.getTimestamp(), "HH:mm:ss.SSS"));
+ imagePauseOverlay.update(text);
+ manageFit(image, data);
+ manageUserOverlays(image, data);
+ }
+ }
+ updateStreamData();
+ }
+
+ void removePauseOverlay() {
+ renderer.removeOverlay(imagePauseOverlay);
+ imagePauseOverlay = null;
+ }
+
+ void saveSnapshot() throws Exception {
+ boolean paused = isPaused();
+ try{
+ if (!paused){
+ setPaused(true);
+ }
+ String snapshotFile = null;
+ synchronized (imageBuffer) {
+ Frame frame = getCurrentFrame();
+ if (frame == null) {
+ throw new Exception("No current image");
+ }
+ ArrayList frames = new ArrayList<>();
+ frames.add(frame);
+ this.saveFrames(cameraName + "_camera_snapshot", frames);
+
+ //Enforce the same timestamp to data & image files.
+ snapshotFile = getContext().getExecutionPars().getPath() + ".png";
+ //renderer.saveSnapshot(snapshotFile, "png", true);
+ ImageBuffer.saveImage(SwingUtils.createImage(renderer), snapshotFile, "png");
+ }
+
+ JPanel panel = new JPanel();
+ GridBagLayout layout = new GridBagLayout();
+ layout.columnWidths = new int[]{0, 180}; //Minimum width
+ layout.rowHeights = new int[]{30, 30, 30}; //Minimum height
+ panel.setLayout(layout);
+ JComboBox comboLogbook = new JComboBox(new String[]{"SwissFEL commissioning data", "SwissFEL commissioning"});
+ JTextField textComment = new JTextField();
+ GridBagConstraints c = new GridBagConstraints();
+ c.gridx = 0;
+ c.gridy = 0;
+ panel.add(new JLabel("Data file:"), c);
+ c.gridy = 1;
+ panel.add(new JLabel("Logbook:"), c);
+ c.gridy = 2;
+ panel.add(new JLabel("Comment:"), c);
+ c.fill = GridBagConstraints.HORIZONTAL;
+ c.gridx = 1;
+ panel.add(textComment, c);
+ c.gridy = 1;
+ panel.add(comboLogbook, c);
+ c.gridy = 0;
+ panel.add(new JLabel(getContext().getExecutionPars().getPath()), c);
+
+ if (SwingUtils.showOption(getTopLevel(), "Success", panel, OptionType.OkCancel) == OptionResult.Yes) {
+ StringBuilder message = new StringBuilder();
+ message.append("Camera: ").append(cameraName).append(" (").
+ append((server != null) ? "server" : "direct").append(")").append("\n");
+ message.append("Screen: ").append(String.valueOf(valueScreen.getLabel().getText())).append("\n");
+ message.append("Filter: ").append(String.valueOf(valueFilter.getLabel().getText())).append("\n");
+ message.append("Data file: ").append(getContext().getExecutionPars().getPath()).append("\n");
+ message.append("Comment: ").append(textComment.getText()).append("\n");
+ //Add slicing message
+ if ((fitOv != null) && (fitOv.length > 5) && (fitOv[fitOv.length - 1] instanceof Overlays.Text)) {
+ Overlays.Text text = (Overlays.Text) fitOv[fitOv.length - 1];
+ message.append(text.getText()).append("\n");
+ }
+ elog((String) comboLogbook.getSelectedItem(), "ScreenPanel Snapshot", message.toString(), new String[]{snapshotFile});
+ }
+ } finally{
+ if (!paused){
+ setPaused(false);
+ }
+ }
+ }
+
+ void saveStack() throws Exception {
+ synchronized (imageBuffer) {
+ saveFrames(cameraName + "_camera_stack", imageBuffer);
+ }
+ SwingUtils.showMessage(getTopLevel(), "Success", "Generated data file:\n" + getContext().getExecutionPars().getPath());
+ }
+
+ public static String getCameraType(String name) {
+ if (name == null) {
+ return "";
+ }
+ for (String s : new String[]{"LCAM"}) {
+ if (name.contains(s)) {
+ return LASER_TYPE;
+ }
+ }
+ for (String s : new String[]{"DSCR", "DSRM", "DLAC"}) {
+ if (name.contains(s)) {
+ return ELECTRONS_TYPE;
+ }
+ }
+ for (String s : new String[]{"PROF", "PPRM", "PSSS", "PSCR", "PSRD"}) {
+ if (name.contains(s)) {
+ return PHOTONICS_TYPE;
+ }
+ }
+ return "Unknown";
+ }
+
+ public Map getProcessingParameters(StreamValue value) throws IOException {
+ return (Map) JsonSerializer.decode(value.getValue("processing_parameters").toString(), Map.class);
+ }
+
+ void saveFrames(String name, ArrayList frames) throws IOException {
+ ArrayList values = new ArrayList<>();
+ for (Frame frame : frames) {
+ values.add(frame.cache);
+ }
+ saveImages(name, values);
+ }
+
+ void saveImages(String name, ArrayList images) throws IOException {
+ int depth = images.size();
+ if (depth == 0) {
+ return;
+ }
+ StreamValue first = images.get(0);
+ String pathRoot = "/camera1/";
+ String pathImage = pathRoot + "image";
+ String pathPid = pathRoot + "pulse_id";
+ String pathTimestampStr = pathRoot + "timestamp_str";
+ Map processingPars = getProcessingParameters(first);
+ String camera = (String) processingPars.get("camera_name");
+ String type = getCameraType(camera);
+
+ int width = ((Number) first.getValue("width")).intValue();
+ int height = ((Number) first.getValue("height")).intValue();
+ Class dataType = first.getValue("image").getClass().getComponentType();
+
+ getContext().setExecutionPars(name);
+ DataManager dm = getContext().getDataManager();
+
+ //Create tables
+ dm.createDataset(pathImage, dataType, new int[]{depth, height, width});
+ dm.createDataset(pathPid, Long.class, new int[]{depth});
+ dm.createDataset(pathTimestampStr, String.class, new int[]{depth});
+ for (String id : first.getIdentifiers()) {
+ Object val = first.getValue(id);
+ if (id.equals("image")) {
+ } else if (id.equals("processing_parameters")) {
+ Map pars = getProcessingParameters(first);
+ for (String key : pars.keySet()) {
+ if ((pars.get(key) != null) && (pars.get(key) instanceof Map)) {
+ for (Object k : ((Map) pars.get(key)).keySet()) {
+ Object v = ((Map) pars.get(key)).get(k);
+ dm.setAttribute(pathImage, key + " " + k, (v == null) ? "" : v);
+ }
+ } else {
+ Object value = pars.get(key);
+ if (value == null) {
+ value = "";
+ } else if (value instanceof List) {
+ Class cls = (((List) value).size() > 0) ? ((List) value).get(0).getClass() : double.class;
+ value = Convert.toPrimitiveArray(value, cls);
+ //value = Convert.toDouble(value);
+ }
+ dm.setAttribute(pathImage, key, value);
+ }
+ }
+ } else if (val.getClass().isArray()) {
+ dm.createDataset(pathRoot + id, Double.class, new int[]{depth, Array.getLength(val)});
+ } else {
+ dm.createDataset(pathRoot + id, val.getClass(), new int[]{depth});
+ }
+ }
+
+ //Add metadata
+ dm.setAttribute(pathRoot, "Camera", camera);
+ dm.setAttribute(pathRoot, "Images", depth);
+ dm.setAttribute(pathRoot, "Interval", -1);
+ dm.setAttribute(pathRoot, "Type", type);
+ if (type.equals(ELECTRONS_TYPE)) {
+ dm.setAttribute(pathRoot, "Screen", String.valueOf(valueScreen.getLabel().getText()));
+ dm.setAttribute(pathRoot, "Filter", String.valueOf(valueFilter.getLabel().getText()));
+ }
+
+ //Save data
+ for (int index = 0; index < depth; index++) {
+ StreamValue streamValue = images.get(index);
+ dm.setItem(pathImage, streamValue.getValue("image"), new long[]{index, 0, 0}, new int[]{1, height, width});
+ dm.setItem(pathPid, streamValue.getPulseId(), index);
+ dm.setItem(pathTimestampStr, Chrono.getTimeStr(streamValue.getTimestamp(), "YYYY-MM-dd HH:mm:ss.SSS"), index);
+
+ for (String id : streamValue.getIdentifiers()) {
+ Object val = streamValue.getValue(id);
+ if (id.equals("image")) {
+ } else if (id.equals("processing_parameters")) {
+ } else if (val.getClass().isArray()) {
+ dm.setItem(pathRoot + id, val, index);
+ } else {
+ dm.setItem(pathRoot + id, val, index);
+ }
+ }
+ }
+ getContext().getDataManager().closeOutput();
+ }
+
+ StandardDialog calibrationDialolg;
+
+ void calibrate() throws Exception {
+ if (server != null) {
+ server.resetRoi();
+ calibrationDialolg = (StandardDialog) getContext().getClassByName("CameraCalibrationDialog").getConstructors()[0].newInstance(new Object[]{getTopLevel(), server.getCurrentCamera(), renderer});
+ SwingUtils.centerComponent(getTopLevel(), calibrationDialolg);
+ calibrationDialolg.setVisible(true);
+ calibrationDialolg.setListener(new StandardDialogListener() {
+ @Override
+ public void onWindowOpened(StandardDialog dlg) {
+ }
+
+ @Override
+ public void onWindowClosed(StandardDialog dlg, boolean accepted) {
+ if (accepted) {
+ //comboCamerasActionPerformed(null);
+ }
+ }
+ });
+ }
+ }
+
+ StandardDialog dataTableDialog;
+ DefaultTableModel dataTableModel;
+ JTable dataTable;
+
+ void showStreamData() {
+ dataTableModel = null;
+ if (server != null) {
+
+ if ((dataTableDialog != null) && (dataTableDialog.isShowing())) {
+ SwingUtils.centerComponent(getTopLevel(), dataTableDialog);
+ dataTableDialog.requestFocus();
+ return;
+ }
+ dataTableModel = new DefaultTableModel(new Object[0][2], new String[]{"Name", "Value"}) {
+ public Class getColumnClass(int columnIndex) {
+ return String.class;
+ }
+
+ public boolean isCellEditable(int rowIndex, int columnIndex) {
+ return false;
+ }
+ };
+ updateStreamData();
+ StreamValue val = server.getStream().take();
+ dataTable = new JTable(dataTableModel);
+ dataTable.setSelectionMode(ListSelectionModel.SINGLE_INTERVAL_SELECTION);
+ dataTable.setCellSelectionEnabled(true);
+ dataTable.getTableHeader().setReorderingAllowed(false);
+ dataTable.getTableHeader().setResizingAllowed(true);
+ dataTableDialog = new StandardDialog(getTopLevel(), "Image Data", false);
+ dataTableDialog.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
+ JScrollPane scrollPane = new JScrollPane();
+ scrollPane.setViewportView(dataTable);
+ scrollPane.setPreferredSize(new Dimension(300, 400));
+ dataTableDialog.setContentPane(scrollPane);
+ dataTableDialog.pack();
+ dataTableDialog.setVisible(true);
+ dataTableDialog.addWindowListener(new WindowAdapter() {
+ @Override
+ public void windowClosing(WindowEvent e) {
+ dataTableModel = null;
+ }
+ });
+ dataTable.addMouseListener(new MouseAdapter() {
+ @Override
+ public void mouseClicked(MouseEvent e) {
+ try {
+ int row = dataTable.getSelectedRow();
+ int col = dataTable.getSelectedColumn();
+ dataTable.setToolTipText(null);
+ if (row > 1) {
+ String id = String.valueOf(dataTable.getModel().getValueAt(row, 0));
+ String locator = String.valueOf(dataTable.getModel().getValueAt(0, 1));
+ String channelId = locator + " " + id;
+ dataTable.setToolTipText(channelId);
+ if ((e.getClickCount() == 2) && (!e.isPopupTrigger())) {
+ if (col == 0) {
+ SwingUtils.showMessage(dataTableDialog, "Channel Identifier", "Copied to clipboard: " + channelId);
+ Clipboard clipboard = Toolkit.getDefaultToolkit().getSystemClipboard();
+ clipboard.setContents(new StringSelection(channelId), (Clipboard clipboard1, Transferable contents) -> {
+ });
+ } else {
+ Object obj = getCurrentFrame().cache.getValue(id);
+ if (id.equals("image")) {
+ } else if (id.equals("processing_parameters")) {
+ Map pars = getProcessingParameters(getCurrentFrame().cache);
+ StringBuilder sb = new StringBuilder();
+ for (String key : pars.keySet()) {
+ sb.append(key).append(" = ").append(Str.toString(pars.get(key), 10)).append("\n");
+ }
+ SwingUtils.showMessage(dataTableDialog, "Processing Parameters", sb.toString());
+ } else if ((obj != null) && (obj.getClass().isArray() || (obj instanceof Number))) {
+ DeviceValueChart chart = new DeviceValueChart();
+ Device dev = null;
+ if (obj.getClass().isArray()) {
+ dev = new ReadableRegisterArray(new ReadableArray() {
+ @Override
+ public Object read() throws IOException, InterruptedException {
+ return Convert.toDouble(getCurrentFrame().cache.getValue(id));
+ }
+
+ @Override
+ public int getSize() {
+ return Array.getLength(getCurrentFrame().cache.getValue(id));
+ }
+ });
+ } else {
+ dev = new ReadableRegisterNumber(new ReadableNumber() {
+ @Override
+ public Object read() throws IOException, InterruptedException {
+ return Convert.toDouble(getCurrentFrame().cache.getValue(id));
+ }
+ });
+ }
+ dev.setPolling(1000);
+ chart.setDevice(dev);
+ JDialog dlg = SwingUtils.showDialog(dataTableDialog, cameraName + " " + id, null, chart);
+ //TODO:
+ //PlotBase plot = chart.getPlot();
+ //if (plot!=null){
+ // plot.setPlotBackgroundColor(Color.BLACK);
+ //}
+ }
+ }
+ }
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }
+ });
+ SwingUtils.centerComponent(getTopLevel(), dataTableDialog);
+ updateStreamData();
+ }
+ }
+
+ volatile boolean updatingStreamData = false;
+
+ void updateStreamData() {
+ if ((dataTableDialog == null) || !dataTableDialog.isShowing() || updatingStreamData) {
+ return;
+ }
+ updatingStreamData = true;
+ SwingUtilities.invokeLater(() -> {
+ updatingStreamData = false;
+ if ((dataTableModel != null) && (server != null)) {
+ StreamValue value = server.getValue();
+ Frame frame = getCurrentFrame();
+ int[] sel_rows = (dataTable == null) ? null : dataTable.getSelectedRows();
+ int[] sel_cols = (dataTable == null) ? null : dataTable.getSelectedColumns();
+ List ids = (value == null) ? new ArrayList<>() : new ArrayList(value.getIdentifiers());
+ if (ids.size() + 4 != dataTableModel.getRowCount()) {
+ dataTableModel.setNumRows(0);
+ try {
+ dataTableModel.addRow(new Object[]{"Locator", server.getUrl() + "/" + ((value == null) ? instanceName : server.getCurrentInstance())});
+ } catch (Exception ex) {
+ dataTableModel.addRow(new Object[]{"Locator", ex.getMessage()});
+ }
+ try {
+ dataTableModel.addRow(new Object[]{"Stream", server.getStreamAddress()});
+ } catch (Exception ex) {
+ dataTableModel.addRow(new Object[]{"Stream", ex.getMessage()});
+ }
+ dataTableModel.addRow(new Object[]{"PID", ""});
+ dataTableModel.addRow(new Object[]{"Timestamp", ""});
+ Collections.sort(ids);
+ for (String id : ids) {
+ dataTableModel.addRow(new Object[]{id, ""});
+ }
+ }
+
+ if ((frame != null) && (frame.cache != null)) {
+ dataTableModel.setValueAt(frame.cache.getPulseId(), 2, 1); //PID
+ dataTableModel.setValueAt(frame.cache.getTimestamp(), 3, 1); //Timestamp
+ for (int i = 4; i < dataTableModel.getRowCount(); i++) {
+ String id = String.valueOf(dataTableModel.getValueAt(i, 0));
+ //Object obj = server.getValue(id);
+ Object obj = frame.cache.getValue(id);
+ if (obj != null) {
+ if (obj.getClass().isArray()) {
+ obj = obj.getClass().getComponentType().getSimpleName() + "[" + Array.getLength(obj) + "]";
+ } else if (obj instanceof Double) {
+ obj = Convert.roundDouble((Double) obj, 1);
+ } else if (obj instanceof Float) {
+ obj = Convert.roundDouble((Float) obj, 1);
+ }
+ }
+ dataTableModel.setValueAt(String.valueOf(obj), i, 1);
+ }
+ }
+ if ((sel_rows != null) && (sel_rows.length > 0)) {
+ //dataTable.setRowSelectionInterval((Integer)Arr.getMin(sel_rows), (Integer)Arr.getMax(sel_rows));
+ dataTable.setRowSelectionInterval(sel_rows[0], sel_rows[sel_rows.length - 1]);
+ }
+ if ((sel_cols != null) && (sel_cols.length > 0)) {
+ //dataTable.setColumnSelectionInterval((Integer)Arr.getMin(sel_cols), (Integer)Arr.getMax(sel_cols));
+ dataTable.setColumnSelectionInterval(sel_cols[0], sel_cols[sel_cols.length - 1]);
+ }
+ }
+ });
+ }
+
+ ImageIcon getIcon(String name) {
+ ImageIcon ret = null;
+ try {
+ //Path path = Paths.get(getClass().getProtectionDomain().getCodeSource().getLocation().getPath(),"resources", name + ".png");
+ String dir = getClass().getProtectionDomain().getCodeSource().getLocation().getPath() + "resources/";
+ if (new File(dir + name + ".png").exists()) {
+ ret = new javax.swing.ImageIcon(dir + name + ".png");
+ } else {
+ ret = new ImageIcon(ch.psi.pshell.ui.App.class.getResource("/ch/psi/pshell/ui/" + name + ".png"));
+ if (MainFrame.isDark()) {
+ try {
+ ret = new ImageIcon(ch.psi.pshell.ui.App.class.getResource("/ch/psi/pshell/ui/dark/" + name + ".png"));
+ } catch (Exception e) {
+ }
+ }
+ }
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ return ret;
+ }
+
+ String getIconName(JButton button) {
+ String ret = button.getIcon().toString();
+ if (ret.indexOf(".") > 0) {
+ ret = ret.substring(0, ret.indexOf("."));
+ }
+ return ret;
+ }
+
+ void setPaused(boolean paused){
+ removePauseOverlay();
+ if (camera != null) {
+ synchronized (imageBuffer) {
+ if (paused) {
+ renderer.pause();
+ panelCameraSelection.setVisible(false);
+ pauseSelection.setVisible(true);
+ if (imageBuffer.size() > 0) {
+ pauseSelection.setEnabled(true);
+ pauseSelection.setMaxValue(imageBuffer.size());
+ pauseSelection.setValue(imageBuffer.size());
+ updatePause();
+ } else {
+ pauseSelection.setEnabled(false);
+ pauseSelection.setMaxValue(1);
+ pauseSelection.setValue(1);
+ }
+ } else {
+ imageBuffer.clear();
+ renderer.resume();
+ //renderer.clear();
+ pauseSelection.setVisible(false);
+ panelCameraSelection.setVisible(true);
+ }
+ }
+ updateStreamData();
+ }
+ }
+
+ boolean isPaused(){
+ return renderer.isPaused();
+ }
+
+ ////////
+ @SuppressWarnings("unchecked")
+ // //GEN-BEGIN:initComponents
+ private void initComponents() {
+
+ buttonGroup1 = new javax.swing.ButtonGroup();
+ buttonGroup2 = new javax.swing.ButtonGroup();
+ buttonGroup3 = new javax.swing.ButtonGroup();
+ buttonGroup4 = new javax.swing.ButtonGroup();
+ jProgressBar1 = new javax.swing.JProgressBar();
+ sidePanel = new javax.swing.JPanel();
+ jPanel3 = new javax.swing.JPanel();
+ buttonZoomFit = new javax.swing.JRadioButton();
+ buttonZoomStretch = new javax.swing.JRadioButton();
+ buttonZoomNormal = new javax.swing.JRadioButton();
+ buttonZoom025 = new javax.swing.JRadioButton();
+ buttonZoom05 = new javax.swing.JRadioButton();
+ buttonZoom2 = new javax.swing.JRadioButton();
+ jPanel2 = new javax.swing.JPanel();
+ checkHistogram = new javax.swing.JCheckBox();
+ comboColormap = new javax.swing.JComboBox();
+ jLabel3 = new javax.swing.JLabel();
+ jLabel4 = new javax.swing.JLabel();
+ buttonFullRange = new javax.swing.JRadioButton();
+ buttonManual = new javax.swing.JRadioButton();
+ buttonAutomatic = new javax.swing.JRadioButton();
+ labelMin = new javax.swing.JLabel();
+ spinnerMin = new javax.swing.JSpinner();
+ spinnerMax = new javax.swing.JSpinner();
+ labelMax = new javax.swing.JLabel();
+ btFixColormapRange = new javax.swing.JButton();
+ jPanel5 = new javax.swing.JPanel();
+ buttonServer = new javax.swing.JRadioButton();
+ buttonDirect = new javax.swing.JRadioButton();
+ textState = new javax.swing.JTextField();
+ filler1 = new javax.swing.Box.Filler(new java.awt.Dimension(0, 0), new java.awt.Dimension(0, 0), new java.awt.Dimension(0, 32767));
+ panelScreen = new javax.swing.JPanel();
+ valueScreen = new ch.psi.pshell.swing.DeviceValuePanel();
+ comboScreen = new javax.swing.JComboBox();
+ panelFilter = new javax.swing.JPanel();
+ valueFilter = new ch.psi.pshell.swing.DeviceValuePanel();
+ comboFilter = new javax.swing.JComboBox();
+ panelScreen2 = new javax.swing.JPanel();
+ checkThreshold = new javax.swing.JCheckBox();
+ spinnerThreshold = new javax.swing.JSpinner();
+ checkBackground = new javax.swing.JCheckBox();
+ checkGoodRegion = new javax.swing.JCheckBox();
+ spinnerGrScale = new javax.swing.JSpinner();
+ spinnerGrThreshold = new javax.swing.JSpinner();
+ labelGrThreshold = new javax.swing.JLabel();
+ labelGrScale = new javax.swing.JLabel();
+ panelSlicing = new javax.swing.JPanel();
+ checkSlicing = new javax.swing.JCheckBox();
+ labelSlScale = new javax.swing.JLabel();
+ spinnerSlScale = new javax.swing.JSpinner();
+ labelSlNumber = new javax.swing.JLabel();
+ spinnerSlNumber = new javax.swing.JSpinner();
+ labelSlOrientation = new javax.swing.JLabel();
+ spinnerSlOrientation = new javax.swing.JSpinner();
+ checkRotation = new javax.swing.JCheckBox();
+ spinnerRotationAngle = new javax.swing.JSpinner();
+ spinnerRotationOrder = new javax.swing.JSpinner();
+ labelOrder = new javax.swing.JLabel();
+ labelMode = new javax.swing.JLabel();
+ spinnerRotationMode = new javax.swing.JSpinner();
+ labelAngle = new javax.swing.JLabel();
+ labelConstant = new javax.swing.JLabel();
+ spinnerRotationConstant = new javax.swing.JSpinner();
+ checkAveraging = new javax.swing.JCheckBox();
+ spinnerAvFrames = new javax.swing.JSpinner();
+ labelAvFrames = new javax.swing.JLabel();
+ labelAvMode = new javax.swing.JLabel();
+ spinnerAvMode = new javax.swing.JSpinner();
+ topPanel = new javax.swing.JPanel();
+ toolBar = new javax.swing.JToolBar();
+ buttonSidePanel = new javax.swing.JToggleButton();
+ buttonStreamData = new javax.swing.JButton();
+ buttonSave = new javax.swing.JToggleButton();
+ buttonGrabBackground = new javax.swing.JButton();
+ buttonPause = new javax.swing.JToggleButton();
+ jSeparator6 = new javax.swing.JToolBar.Separator();
+ buttonMarker = new javax.swing.JToggleButton();
+ buttonProfile = new javax.swing.JToggleButton();
+ buttonFit = new javax.swing.JToggleButton();
+ buttonReticle = new javax.swing.JToggleButton();
+ buttonScale = new javax.swing.JToggleButton();
+ buttonTitle = new javax.swing.JToggleButton();
+ pauseSelection = new ch.psi.pshell.swing.ValueSelection();
+ panelCameraSelection = new javax.swing.JPanel();
+ jLabel1 = new javax.swing.JLabel();
+ comboCameras = new javax.swing.JComboBox();
+ jLabel5 = new javax.swing.JLabel();
+ comboType = new javax.swing.JComboBox();
+ renderer = new ch.psi.pshell.imaging.Renderer();
+
+ setPreferredSize(new java.awt.Dimension(873, 600));
+
+ jPanel3.setBorder(javax.swing.BorderFactory.createTitledBorder("Zoom"));
+
+ buttonGroup1.add(buttonZoomFit);
+ buttonZoomFit.setText("Fit");
+ buttonZoomFit.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonZoomFitActionPerformed(evt);
+ }
+ });
+
+ buttonGroup1.add(buttonZoomStretch);
+ buttonZoomStretch.setText("Stretch");
+ buttonZoomStretch.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonZoomStretchActionPerformed(evt);
+ }
+ });
+
+ buttonGroup1.add(buttonZoomNormal);
+ buttonZoomNormal.setText("Normal");
+ buttonZoomNormal.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonZoomNormalActionPerformed(evt);
+ }
+ });
+
+ buttonGroup1.add(buttonZoom025);
+ buttonZoom025.setText("1/4");
+ buttonZoom025.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonZoom025ActionPerformed(evt);
+ }
+ });
+
+ buttonGroup1.add(buttonZoom05);
+ buttonZoom05.setText("1/2");
+ buttonZoom05.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonZoom05ActionPerformed(evt);
+ }
+ });
+
+ buttonGroup1.add(buttonZoom2);
+ buttonZoom2.setText("2");
+ buttonZoom2.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonZoom2ActionPerformed(evt);
+ }
+ });
+
+ javax.swing.GroupLayout jPanel3Layout = new javax.swing.GroupLayout(jPanel3);
+ jPanel3.setLayout(jPanel3Layout);
+ jPanel3Layout.setHorizontalGroup(
+ jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(jPanel3Layout.createSequentialGroup()
+ .addContainerGap()
+ .addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(buttonZoomFit)
+ .addComponent(buttonZoomNormal)
+ .addComponent(buttonZoomStretch))
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(buttonZoom025)
+ .addComponent(buttonZoom05)
+ .addComponent(buttonZoom2))
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ );
+ jPanel3Layout.setVerticalGroup(
+ jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(jPanel3Layout.createSequentialGroup()
+ .addGap(4, 4, 4)
+ .addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(buttonZoomNormal)
+ .addComponent(buttonZoom025))
+ .addGap(0, 0, 0)
+ .addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(buttonZoomFit)
+ .addComponent(buttonZoom05))
+ .addGap(0, 0, 0)
+ .addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(buttonZoomStretch)
+ .addComponent(buttonZoom2))
+ .addContainerGap())
+ );
+
+ jPanel2.setBorder(javax.swing.BorderFactory.createTitledBorder("Colormap"));
+
+ checkHistogram.setText("Histogram");
+ checkHistogram.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ checkHistogramActionPerformed(evt);
+ }
+ });
+
+ comboColormap.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ onChangeColormap(evt);
+ }
+ });
+
+ jLabel3.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ jLabel3.setText("Type:");
+
+ jLabel4.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ jLabel4.setText("Range:");
+
+ buttonGroup3.add(buttonFullRange);
+ buttonFullRange.setText("Full");
+ buttonFullRange.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ onChangeColormap(evt);
+ }
+ });
+
+ buttonGroup3.add(buttonManual);
+ buttonManual.setText("Manual");
+ buttonManual.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ onChangeColormap(evt);
+ }
+ });
+
+ buttonGroup3.add(buttonAutomatic);
+ buttonAutomatic.setText("Automatic");
+ buttonAutomatic.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ onChangeColormap(evt);
+ }
+ });
+
+ labelMin.setText("Min:");
+
+ spinnerMin.setModel(new javax.swing.SpinnerNumberModel(0, 0, 65535, 1));
+ spinnerMin.setEnabled(false);
+ spinnerMin.setPreferredSize(new java.awt.Dimension(77, 20));
+ spinnerMin.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ onChangeColormapRange(evt);
+ }
+ });
+
+ spinnerMax.setModel(new javax.swing.SpinnerNumberModel(255, 0, 65535, 1));
+ spinnerMax.setEnabled(false);
+ spinnerMax.setPreferredSize(new java.awt.Dimension(77, 20));
+ spinnerMax.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ onChangeColormapRange(evt);
+ }
+ });
+
+ labelMax.setText("Max:");
+
+ btFixColormapRange.setText("Fix");
+ btFixColormapRange.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ btFixColormapRangeActionPerformed(evt);
+ }
+ });
+
+ javax.swing.GroupLayout jPanel2Layout = new javax.swing.GroupLayout(jPanel2);
+ jPanel2.setLayout(jPanel2Layout);
+ jPanel2Layout.setHorizontalGroup(
+ jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(jPanel2Layout.createSequentialGroup()
+ .addGap(4, 4, 4)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(jLabel3)
+ .addComponent(jLabel4))
+ .addGap(4, 4, 4)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(buttonAutomatic)
+ .addComponent(buttonFullRange)
+ .addComponent(buttonManual)
+ .addComponent(comboColormap, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel2Layout.createSequentialGroup()
+ .addComponent(labelMax)
+ .addGap(2, 2, 2)
+ .addComponent(spinnerMax, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addComponent(checkHistogram, javax.swing.GroupLayout.Alignment.TRAILING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel2Layout.createSequentialGroup()
+ .addComponent(labelMin)
+ .addGap(2, 2, 2)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false)
+ .addComponent(btFixColormapRange, javax.swing.GroupLayout.Alignment.TRAILING)
+ .addComponent(spinnerMin, javax.swing.GroupLayout.Alignment.TRAILING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))))
+ .addContainerGap())
+ );
+
+ jPanel2Layout.linkSize(javax.swing.SwingConstants.HORIZONTAL, new java.awt.Component[] {btFixColormapRange, spinnerMax, spinnerMin});
+
+ jPanel2Layout.linkSize(javax.swing.SwingConstants.HORIZONTAL, new java.awt.Component[] {jLabel3, jLabel4});
+
+ jPanel2Layout.setVerticalGroup(
+ jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel2Layout.createSequentialGroup()
+ .addGap(4, 4, 4)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(comboColormap, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(jLabel3)
+ .addComponent(checkHistogram))
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(buttonAutomatic)
+ .addComponent(jLabel4)
+ .addComponent(btFixColormapRange, javax.swing.GroupLayout.PREFERRED_SIZE, 26, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addGap(0, 0, 0)
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(labelMin)
+ .addComponent(spinnerMin, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(buttonFullRange))
+ .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(buttonManual)
+ .addComponent(labelMax)
+ .addComponent(spinnerMax, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addContainerGap())
+ );
+
+ jPanel5.setBorder(javax.swing.BorderFactory.createTitledBorder("Source"));
+
+ buttonGroup4.add(buttonServer);
+ buttonServer.setSelected(true);
+ buttonServer.setText("Server");
+ buttonServer.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonServerActionPerformed(evt);
+ }
+ });
+
+ buttonGroup4.add(buttonDirect);
+ buttonDirect.setText("Direct");
+ buttonDirect.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonDirectActionPerformed(evt);
+ }
+ });
+
+ textState.setEditable(false);
+ textState.setHorizontalAlignment(javax.swing.JTextField.CENTER);
+ textState.setDisabledTextColor(new java.awt.Color(0, 0, 0));
+ textState.setEnabled(false);
+
+ javax.swing.GroupLayout jPanel5Layout = new javax.swing.GroupLayout(jPanel5);
+ jPanel5.setLayout(jPanel5Layout);
+ jPanel5Layout.setHorizontalGroup(
+ jPanel5Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(jPanel5Layout.createSequentialGroup()
+ .addContainerGap()
+ .addComponent(buttonServer)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(buttonDirect)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(textState, javax.swing.GroupLayout.PREFERRED_SIZE, 80, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addContainerGap())
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel5Layout.createSequentialGroup()
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(filler1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addGap(56, 56, 56))
+ );
+ jPanel5Layout.setVerticalGroup(
+ jPanel5Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(jPanel5Layout.createSequentialGroup()
+ .addGap(4, 4, 4)
+ .addGroup(jPanel5Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(jPanel5Layout.createSequentialGroup()
+ .addComponent(textState, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(filler1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addGroup(jPanel5Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(buttonServer)
+ .addComponent(buttonDirect)))
+ .addContainerGap())
+ );
+
+ panelScreen.setBorder(javax.swing.BorderFactory.createTitledBorder("Screen"));
+
+ comboScreen.setEnabled(false);
+ comboScreen.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ comboScreenActionPerformed(evt);
+ }
+ });
+
+ javax.swing.GroupLayout panelScreenLayout = new javax.swing.GroupLayout(panelScreen);
+ panelScreen.setLayout(panelScreenLayout);
+ panelScreenLayout.setHorizontalGroup(
+ panelScreenLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelScreenLayout.createSequentialGroup()
+ .addContainerGap()
+ .addGroup(panelScreenLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(valueScreen, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(comboScreen, 0, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ .addContainerGap())
+ );
+ panelScreenLayout.setVerticalGroup(
+ panelScreenLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelScreenLayout.createSequentialGroup()
+ .addGap(4, 4, 4)
+ .addComponent(comboScreen, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(valueScreen, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addContainerGap())
+ );
+
+ panelFilter.setBorder(javax.swing.BorderFactory.createTitledBorder("Filter"));
+
+ comboFilter.setEnabled(false);
+ comboFilter.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ comboFilterActionPerformed(evt);
+ }
+ });
+
+ javax.swing.GroupLayout panelFilterLayout = new javax.swing.GroupLayout(panelFilter);
+ panelFilter.setLayout(panelFilterLayout);
+ panelFilterLayout.setHorizontalGroup(
+ panelFilterLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelFilterLayout.createSequentialGroup()
+ .addContainerGap()
+ .addGroup(panelFilterLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(valueFilter, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(comboFilter, 0, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ .addContainerGap())
+ );
+ panelFilterLayout.setVerticalGroup(
+ panelFilterLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelFilterLayout.createSequentialGroup()
+ .addGap(4, 4, 4)
+ .addComponent(comboFilter, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(valueFilter, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ );
+
+ panelScreen2.setBorder(javax.swing.BorderFactory.createTitledBorder("Pipeline"));
+
+ checkThreshold.setText("Threshold");
+ checkThreshold.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ checkThresholdActionPerformed(evt);
+ }
+ });
+
+ spinnerThreshold.setModel(new javax.swing.SpinnerNumberModel(0.0d, 0.0d, 99999.0d, 1.0d));
+ spinnerThreshold.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerThresholdonChange(evt);
+ }
+ });
+
+ checkBackground.setText("Subtract Background");
+ checkBackground.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ checkBackgroundActionPerformed(evt);
+ }
+ });
+
+ checkGoodRegion.setText("Good Region");
+ checkGoodRegion.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ checkGoodRegionActionPerformed(evt);
+ }
+ });
+
+ spinnerGrScale.setModel(new javax.swing.SpinnerNumberModel(3.0d, 0.01d, 99999.0d, 1.0d));
+ spinnerGrScale.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerGrThresholdonChange(evt);
+ }
+ });
+
+ spinnerGrThreshold.setModel(new javax.swing.SpinnerNumberModel(0.5d, 0.04d, 1.0d, 0.1d));
+ spinnerGrThreshold.setPreferredSize(new java.awt.Dimension(92, 20));
+ spinnerGrThreshold.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerGrThresholdonChange(evt);
+ }
+ });
+
+ labelGrThreshold.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelGrThreshold.setText("Threshold:");
+
+ labelGrScale.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelGrScale.setText("Scale:");
+
+ checkSlicing.setText("Slicing");
+ checkSlicing.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ checkSlicingActionPerformed(evt);
+ }
+ });
+
+ labelSlScale.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelSlScale.setText("Scale:");
+
+ spinnerSlScale.setModel(new javax.swing.SpinnerNumberModel(3.0d, 0.01d, 99999.0d, 1.0d));
+ spinnerSlScale.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerSlicingChange(evt);
+ }
+ });
+
+ labelSlNumber.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelSlNumber.setText("Slices:");
+
+ spinnerSlNumber.setModel(new javax.swing.SpinnerNumberModel(2, 0, 1000, 1));
+ spinnerSlNumber.setPreferredSize(new java.awt.Dimension(92, 20));
+ spinnerSlNumber.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerSlicingChange(evt);
+ }
+ });
+
+ labelSlOrientation.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelSlOrientation.setText("Orientation:");
+
+ spinnerSlOrientation.setModel(new javax.swing.SpinnerListModel(new String[] {"vertical", "horizontal"}));
+ spinnerSlOrientation.setPreferredSize(new java.awt.Dimension(92, 20));
+ spinnerSlOrientation.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerSlicingChange(evt);
+ }
+ });
+
+ javax.swing.GroupLayout panelSlicingLayout = new javax.swing.GroupLayout(panelSlicing);
+ panelSlicing.setLayout(panelSlicingLayout);
+ panelSlicingLayout.setHorizontalGroup(
+ panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelSlicingLayout.createSequentialGroup()
+ .addContainerGap()
+ .addGroup(panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelSlicingLayout.createSequentialGroup()
+ .addComponent(checkSlicing)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addGroup(panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelSlicingLayout.createSequentialGroup()
+ .addComponent(labelSlNumber)
+ .addGap(2, 2, 2)
+ .addComponent(spinnerSlNumber, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelSlicingLayout.createSequentialGroup()
+ .addComponent(labelSlScale)
+ .addGap(2, 2, 2)
+ .addComponent(spinnerSlScale, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))))
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelSlicingLayout.createSequentialGroup()
+ .addGap(0, 0, Short.MAX_VALUE)
+ .addComponent(labelSlOrientation)
+ .addGap(2, 2, 2)
+ .addComponent(spinnerSlOrientation, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)))
+ .addContainerGap())
+ );
+
+ panelSlicingLayout.linkSize(javax.swing.SwingConstants.HORIZONTAL, new java.awt.Component[] {spinnerSlNumber, spinnerSlOrientation, spinnerSlScale});
+
+ panelSlicingLayout.setVerticalGroup(
+ panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelSlicingLayout.createSequentialGroup()
+ .addGroup(panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(checkSlicing)
+ .addGroup(panelSlicingLayout.createSequentialGroup()
+ .addGroup(panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerSlNumber, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelSlNumber))
+ .addGap(0, 0, 0)
+ .addGroup(panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerSlScale, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelSlScale))))
+ .addGap(0, 0, 0)
+ .addGroup(panelSlicingLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerSlOrientation, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelSlOrientation)))
+ );
+
+ panelSlicingLayout.linkSize(javax.swing.SwingConstants.VERTICAL, new java.awt.Component[] {spinnerSlNumber, spinnerSlOrientation, spinnerSlScale});
+
+ checkRotation.setText("Rotation");
+ checkRotation.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ checkRotationActionPerformed(evt);
+ }
+ });
+
+ spinnerRotationAngle.setModel(new javax.swing.SpinnerNumberModel(0.0d, -360.0d, 360.0d, 1.0d));
+ spinnerRotationAngle.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerRotationAngleStateChanged(evt);
+ }
+ });
+
+ spinnerRotationOrder.setModel(new javax.swing.SpinnerNumberModel(1, 1, 5, 1));
+ spinnerRotationOrder.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerRotationAngleStateChanged(evt);
+ }
+ });
+
+ labelOrder.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelOrder.setText("Order:");
+
+ labelMode.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelMode.setText("Mode:");
+
+ spinnerRotationMode.setModel(new javax.swing.SpinnerListModel(new String[] {"constant", "reflect", "nearest", "mirror", "wrap"}));
+ spinnerRotationMode.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerRotationAngleStateChanged(evt);
+ }
+ });
+
+ labelAngle.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelAngle.setText("Angle:");
+
+ labelConstant.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelConstant.setText("Constant:");
+
+ spinnerRotationConstant.setModel(new javax.swing.SpinnerNumberModel(0, 0, 99999, 1));
+ spinnerRotationConstant.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerRotationAngleStateChanged(evt);
+ }
+ });
+
+ checkAveraging.setText("Averaging");
+ checkAveraging.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ checkAveragingActionPerformed(evt);
+ }
+ });
+
+ spinnerAvFrames.setModel(new javax.swing.SpinnerNumberModel(1, 1, 1000, 1));
+ spinnerAvFrames.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerAvFramesStateChanged(evt);
+ }
+ });
+
+ labelAvFrames.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelAvFrames.setText("Frames:");
+
+ labelAvMode.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
+ labelAvMode.setText("Mode:");
+
+ spinnerAvMode.setModel(new javax.swing.SpinnerListModel(new String[] {"single", "window"}));
+ spinnerAvMode.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerAvModeonChange(evt);
+ }
+ });
+
+ javax.swing.GroupLayout panelScreen2Layout = new javax.swing.GroupLayout(panelScreen2);
+ panelScreen2.setLayout(panelScreen2Layout);
+ panelScreen2Layout.setHorizontalGroup(
+ panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelScreen2Layout.createSequentialGroup()
+ .addContainerGap()
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelScreen2Layout.createSequentialGroup()
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(checkGoodRegion)
+ .addComponent(checkRotation)
+ .addComponent(checkThreshold)
+ .addComponent(checkAveraging))
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(labelOrder, javax.swing.GroupLayout.Alignment.TRAILING)
+ .addComponent(labelAngle, javax.swing.GroupLayout.Alignment.TRAILING))
+ .addComponent(labelGrScale, javax.swing.GroupLayout.Alignment.TRAILING)))
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelScreen2Layout.createSequentialGroup()
+ .addGap(0, 0, Short.MAX_VALUE)
+ .addComponent(labelAvMode)))
+ .addGap(2, 2, 2)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false)
+ .addComponent(spinnerGrThreshold, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(spinnerGrScale)
+ .addComponent(spinnerThreshold)
+ .addComponent(spinnerRotationOrder)
+ .addComponent(spinnerRotationMode)
+ .addComponent(spinnerRotationAngle)
+ .addComponent(spinnerRotationConstant)
+ .addComponent(spinnerAvFrames)
+ .addComponent(spinnerAvMode))
+ .addContainerGap())
+ .addComponent(panelSlicing, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelScreen2Layout.createSequentialGroup()
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(labelGrThreshold, javax.swing.GroupLayout.Alignment.TRAILING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, panelScreen2Layout.createSequentialGroup()
+ .addComponent(labelConstant)
+ .addGap(2, 2, 2)))
+ .addGap(106, 106, 106))
+ .addGroup(panelScreen2Layout.createSequentialGroup()
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelScreen2Layout.createSequentialGroup()
+ .addGap(6, 6, 6)
+ .addComponent(checkBackground))
+ .addGroup(panelScreen2Layout.createSequentialGroup()
+ .addGap(111, 111, 111)
+ .addComponent(labelAvFrames))
+ .addGroup(panelScreen2Layout.createSequentialGroup()
+ .addGap(122, 122, 122)
+ .addComponent(labelMode)))
+ .addGap(106, 106, 106))
+ );
+
+ panelScreen2Layout.linkSize(javax.swing.SwingConstants.HORIZONTAL, new java.awt.Component[] {spinnerAvFrames, spinnerGrScale, spinnerGrThreshold, spinnerRotationAngle, spinnerRotationConstant, spinnerRotationMode, spinnerRotationOrder, spinnerThreshold});
+
+ panelScreen2Layout.setVerticalGroup(
+ panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelScreen2Layout.createSequentialGroup()
+ .addContainerGap()
+ .addComponent(checkBackground)
+ .addGap(2, 2, 2)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(checkThreshold)
+ .addComponent(spinnerThreshold, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addGap(2, 2, 2)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(checkAveraging)
+ .addComponent(spinnerAvFrames, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelAvFrames))
+ .addGap(2, 2, 2)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerAvMode, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelAvMode))
+ .addGap(2, 2, 2)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(checkRotation)
+ .addComponent(spinnerRotationAngle, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelAngle))
+ .addGap(0, 0, 0)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerRotationOrder, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelOrder))
+ .addGap(0, 0, 0)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerRotationMode, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelMode))
+ .addGap(0, 0, 0)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerRotationConstant, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelConstant))
+ .addGap(2, 2, 2)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(checkGoodRegion)
+ .addComponent(spinnerGrScale, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelGrScale))
+ .addGap(0, 0, 0)
+ .addGroup(panelScreen2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(spinnerGrThreshold, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(labelGrThreshold))
+ .addGap(2, 2, 2)
+ .addComponent(panelSlicing, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addContainerGap())
+ );
+
+ panelScreen2Layout.linkSize(javax.swing.SwingConstants.VERTICAL, new java.awt.Component[] {spinnerGrScale, spinnerGrThreshold, spinnerRotationAngle, spinnerRotationConstant, spinnerRotationMode, spinnerRotationOrder, spinnerThreshold});
+
+ javax.swing.GroupLayout sidePanelLayout = new javax.swing.GroupLayout(sidePanel);
+ sidePanel.setLayout(sidePanelLayout);
+ sidePanelLayout.setHorizontalGroup(
+ sidePanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(sidePanelLayout.createSequentialGroup()
+ .addContainerGap()
+ .addGroup(sidePanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING, false)
+ .addComponent(jPanel5, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(jPanel3, javax.swing.GroupLayout.Alignment.LEADING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(jPanel2, javax.swing.GroupLayout.Alignment.LEADING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(panelScreen2, javax.swing.GroupLayout.Alignment.LEADING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(panelScreen, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(panelFilter, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ );
+ sidePanelLayout.setVerticalGroup(
+ sidePanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(sidePanelLayout.createSequentialGroup()
+ .addGap(0, 0, 0)
+ .addComponent(jPanel5, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(panelScreen2, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(jPanel3, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(jPanel2, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(panelScreen, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(panelFilter, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ );
+
+ toolBar.setFloatable(false);
+ toolBar.setRollover(true);
+
+ buttonSidePanel.setIcon(getIcon("List"));
+ buttonSidePanel.setSelected(true);
+ buttonSidePanel.setText(" ");
+ buttonSidePanel.setToolTipText("Show Side Panel");
+ buttonSidePanel.setFocusable(false);
+ buttonSidePanel.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonSidePanel.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonSidePanelActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonSidePanel);
+
+ buttonStreamData.setIcon(getIcon("Details"));
+ buttonStreamData.setText(" ");
+ buttonStreamData.setToolTipText("Show Data Window");
+ buttonStreamData.setFocusable(false);
+ buttonStreamData.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonStreamData.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonStreamDataActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonStreamData);
+
+ buttonSave.setIcon(getIcon("Save"));
+ buttonSave.setText(" ");
+ buttonSave.setToolTipText("Save Snapshot");
+ buttonSave.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonSave.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonSaveActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonSave);
+
+ buttonGrabBackground.setIcon(getIcon("Background"));
+ buttonGrabBackground.setText(" ");
+ buttonGrabBackground.setToolTipText("Grab Background");
+ buttonGrabBackground.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonGrabBackground.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonGrabBackgroundActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonGrabBackground);
+
+ buttonPause.setIcon(getIcon("Pause"));
+ buttonPause.setText(" ");
+ buttonPause.setToolTipText("Pause");
+ buttonPause.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonPause.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonPauseActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonPause);
+
+ jSeparator6.setMaximumSize(new java.awt.Dimension(20, 32767));
+ jSeparator6.setPreferredSize(new java.awt.Dimension(20, 0));
+ jSeparator6.setRequestFocusEnabled(false);
+ toolBar.add(jSeparator6);
+
+ buttonMarker.setIcon(getIcon("Marker"));
+ buttonMarker.setText(" ");
+ buttonMarker.setToolTipText("Show Marker");
+ buttonMarker.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonMarker.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonMarkerActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonMarker);
+
+ buttonProfile.setIcon(getIcon("Profile"
+ + ""));
+ buttonProfile.setSelected(true);
+ buttonProfile.setText(" ");
+ buttonProfile.setToolTipText("Show Image Profile");
+ buttonProfile.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonProfile.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonProfileActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonProfile);
+
+ buttonFit.setIcon(getIcon("Fit"));
+ buttonFit.setSelected(true);
+ buttonFit.setText(" ");
+ buttonFit.setToolTipText("Show Fit");
+ buttonFit.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonFit.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonFitActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonFit);
+
+ buttonReticle.setIcon(getIcon("Reticule"));
+ buttonReticle.setSelected(true);
+ buttonReticle.setText(" ");
+ buttonReticle.setToolTipText("Show Reticle");
+ buttonReticle.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonReticle.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonReticleActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonReticle);
+
+ buttonScale.setIcon(getIcon("Scale"));
+ buttonScale.setSelected(true);
+ buttonScale.setText(" ");
+ buttonScale.setToolTipText("Show Colormap Scale");
+ buttonScale.setFocusable(false);
+ buttonScale.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonScale.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonScaleActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonScale);
+
+ buttonTitle.setIcon(getIcon("Title"));
+ buttonTitle.setSelected(true);
+ buttonTitle.setText(" ");
+ buttonTitle.setToolTipText("Show Camera Name");
+ buttonTitle.setFocusable(false);
+ buttonTitle.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER);
+ buttonTitle.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonTitleActionPerformed(evt);
+ }
+ });
+ toolBar.add(buttonTitle);
+
+ pauseSelection.setDecimals(0);
+
+ jLabel1.setText("Camera:");
+
+ comboCameras.setFont(new java.awt.Font("Dialog", 1, 14)); // NOI18N
+ comboCameras.setMaximumRowCount(30);
+ comboCameras.setMinimumSize(new java.awt.Dimension(127, 27));
+ comboCameras.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ comboCamerasActionPerformed(evt);
+ }
+ });
+
+ jLabel5.setText("Type:");
+
+ comboType.setFont(new java.awt.Font("Dialog", 1, 14)); // NOI18N
+ comboType.setMaximumRowCount(30);
+ comboType.setModel(new javax.swing.DefaultComboBoxModel(new String[] { "All", "Laser", "Electrons", "Photonics" }));
+ comboType.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ comboTypeActionPerformed(evt);
+ }
+ });
+
+ javax.swing.GroupLayout panelCameraSelectionLayout = new javax.swing.GroupLayout(panelCameraSelection);
+ panelCameraSelection.setLayout(panelCameraSelectionLayout);
+ panelCameraSelectionLayout.setHorizontalGroup(
+ panelCameraSelectionLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelCameraSelectionLayout.createSequentialGroup()
+ .addContainerGap()
+ .addComponent(jLabel1)
+ .addGap(0, 0, 0)
+ .addComponent(comboCameras, javax.swing.GroupLayout.PREFERRED_SIZE, 222, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(jLabel5)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(comboType, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addGap(0, 0, 0))
+ );
+ panelCameraSelectionLayout.setVerticalGroup(
+ panelCameraSelectionLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(panelCameraSelectionLayout.createSequentialGroup()
+ .addGap(0, 0, 0)
+ .addGroup(panelCameraSelectionLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(comboType, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(jLabel5)
+ .addComponent(jLabel1)
+ .addComponent(comboCameras, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
+ .addGap(0, 0, 0))
+ );
+
+ javax.swing.GroupLayout topPanelLayout = new javax.swing.GroupLayout(topPanel);
+ topPanel.setLayout(topPanelLayout);
+ topPanelLayout.setHorizontalGroup(
+ topPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, topPanelLayout.createSequentialGroup()
+ .addComponent(toolBar, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addGap(18, 18, 18)
+ .addComponent(panelCameraSelection, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addGap(18, 18, 18)
+ .addComponent(pauseSelection, javax.swing.GroupLayout.PREFERRED_SIZE, 334, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addContainerGap())
+ );
+ topPanelLayout.setVerticalGroup(
+ topPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
+ .addGroup(topPanelLayout.createSequentialGroup()
+ .addGap(1, 1, 1)
+ .addGroup(topPanelLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.CENTER)
+ .addComponent(pauseSelection, javax.swing.GroupLayout.PREFERRED_SIZE, 29, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(toolBar, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addComponent(panelCameraSelection, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)))
+ );
+
+ javax.swing.GroupLayout layout = new javax.swing.GroupLayout(this);
+ this.setLayout(layout);
+ layout.setHorizontalGroup(
+ layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(layout.createSequentialGroup()
+ .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
+ .addGroup(javax.swing.GroupLayout.Alignment.LEADING, layout.createSequentialGroup()
+ .addComponent(sidePanel, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(renderer, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ .addGroup(javax.swing.GroupLayout.Alignment.LEADING, layout.createSequentialGroup()
+ .addContainerGap()
+ .addComponent(topPanel, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)))
+ .addContainerGap())
+ );
+ layout.setVerticalGroup(
+ layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGroup(layout.createSequentialGroup()
+ .addComponent(topPanel, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(sidePanel, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(renderer, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)))
+ );
+ }// //GEN-END:initComponents
+
+ private void buttonZoomFitActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonZoomFitActionPerformed
+ try {
+ renderer.setMode(RendererMode.Fit);
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonZoomFitActionPerformed
+
+ private void buttonZoomStretchActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonZoomStretchActionPerformed
+ try {
+ renderer.setMode(RendererMode.Stretch);
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonZoomStretchActionPerformed
+
+ private void buttonZoomNormalActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonZoomNormalActionPerformed
+ try {
+ renderer.setMode(RendererMode.Fixed);
+ centralizeRenderer();
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonZoomNormalActionPerformed
+
+ private void onChangeColormap(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_onChangeColormap
+ try {
+ if ((camera != null) && (camera instanceof ColormapSource) && !updatingColormap) {
+ ColormapSource source = (ColormapSource) camera;
+ Color colorReticule = new Color(16, 16, 16);
+ Color colorMarker = new Color(128, 128, 128);
+ Colormap colormap = (Colormap) comboColormap.getSelectedItem();
+ source.getConfig().colormap = (colormap == null) ? Colormap.Flame : colormap;
+ switch (source.getConfig().colormap) {
+ case Grayscale:
+ case Inverted:
+ case Red:
+ case Green:
+ case Blue:
+ colorReticule = new Color(0, 192, 0);
+ colorMarker = new Color(64, 255, 64);
+ break;
+ case Flame:
+ colorReticule = new Color(0, 192, 0);
+ colorMarker = new Color(64, 255, 64);
+ break;
+ }
+
+ renderer.setPenReticle(new Pen(colorReticule));
+ renderer.setPenProfile(new Pen(colorReticule, 0));
+ renderer.setPenMarker(new Pen(colorMarker, 2));
+ renderer.setShowReticle(false);
+ checkReticle();
+ source.getConfig().colormapAutomatic = buttonAutomatic.isSelected();
+ source.getConfig().colormapMin = buttonFullRange.isSelected() ? Double.NaN : (Integer) spinnerMin.getValue();
+ source.getConfig().colormapMax = buttonFullRange.isSelected() ? Double.NaN : (Integer) spinnerMax.getValue();
+ try {
+ source.getConfig().save();
+ } catch (Exception ex) {
+ Logger.getLogger(getClass().getName()).log(Level.WARNING, null, ex);
+ }
+ source.refresh();
+ if (buttonPause.isSelected()) {
+ updatePause();
+ }
+ updateColormap();
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_onChangeColormap
+
+ private void onChangeColormapRange(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_onChangeColormapRange
+ onChangeColormap(null);
+ }//GEN-LAST:event_onChangeColormapRange
+
+ private void buttonZoom025ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonZoom025ActionPerformed
+ renderer.setZoom(0.25);
+ renderer.setMode(RendererMode.Zoom);
+ centralizeRenderer();
+ }//GEN-LAST:event_buttonZoom025ActionPerformed
+
+ private void buttonZoom05ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonZoom05ActionPerformed
+ renderer.setZoom(0.5);
+ renderer.setMode(RendererMode.Zoom);
+ centralizeRenderer();
+ }//GEN-LAST:event_buttonZoom05ActionPerformed
+
+ private void buttonServerActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonServerActionPerformed
+ if (!usingServer) {
+ usingServer = true;
+ requestCameraListUpdate = true;
+ }
+ comboCamerasActionPerformed(null);
+ }//GEN-LAST:event_buttonServerActionPerformed
+
+ private void buttonDirectActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonDirectActionPerformed
+ if (usingServer) {
+ usingServer = false;
+ requestCameraListUpdate = true;
+ }
+ comboCamerasActionPerformed(null);
+ }//GEN-LAST:event_buttonDirectActionPerformed
+
+ private void comboScreenActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_comboScreenActionPerformed
+
+ comboScreen.setEnabled(false);
+ new Thread(new Runnable() {
+ @Override
+ public void run() {
+ ChannelInteger setpoint = null;
+ try {
+ int index = comboScreen.getSelectedIndex();
+ if (index >= 0) {
+ if (cameraName.contains("DSRM")) {
+ setpoint = new ChannelInteger(null, cameraName + ":POSITION_SP");
+ } else {
+ setpoint = new ChannelInteger(null, cameraName + ":SET_SCREEN1_POS");
+ }
+ setpoint.initialize();
+ Integer readback = setpoint.read();
+ if ((readback == null) || (setpoint.read() != index)) {
+ setpoint.write(index);
+ //Must be threaded to control the laser because of sleep in setLaserState
+ /*
+ boolean laserOn = getLaserState();
+ if (laserOn) {
+ setLaserState(false);
+ }
+ try {
+ setpoint.write(index);
+ } finally {
+ if (laserOn) {
+ setLaserState(true);
+ }
+ }
+ */
+ }
+ screen.read();
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ } finally {
+ comboScreen.setEnabled(true);
+ if (setpoint != null) {
+ setpoint.close();
+ }
+ }
+ }
+ }).start();
+ }//GEN-LAST:event_comboScreenActionPerformed
+
+ private void comboFilterActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_comboFilterActionPerformed
+ try {
+ String setpoint = (String) comboFilter.getSelectedItem();
+ if (setpoint != null) {
+ if (!setpoint.equals(filter.read())) {
+ filter.write(setpoint);
+ }
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_comboFilterActionPerformed
+
+ private void checkHistogramActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_checkHistogramActionPerformed
+ try {
+ setHistogramVisible(checkHistogram.isSelected());
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_checkHistogramActionPerformed
+
+ private void buttonZoom2ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonZoom2ActionPerformed
+ renderer.setZoom(2.0);
+ renderer.setMode(RendererMode.Zoom);
+ centralizeRenderer();
+ }//GEN-LAST:event_buttonZoom2ActionPerformed
+
+ private void spinnerThresholdonChange(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerThresholdonChange
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ server.setThreshold((Double) spinnerThreshold.getValue());
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_spinnerThresholdonChange
+
+ private void checkBackgroundActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_checkBackgroundActionPerformed
+ if (server != null) {
+ if (!updatingServerControls) {
+ try {
+ if (server.isStarted()) {
+ server.setBackgroundSubtraction(checkBackground.isSelected());
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ updatingServerControls = true;
+ checkBackground.setSelected(false);
+ updatingServerControls = false;
+
+ }
+ }
+ } else {
+ camera.setBackgroundEnabled(checkBackground.isSelected());
+ }
+ }//GEN-LAST:event_checkBackgroundActionPerformed
+
+ private void checkThresholdActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_checkThresholdActionPerformed
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ spinnerThreshold.setVisible(checkThreshold.isSelected());
+ server.setThreshold(checkThreshold.isSelected() ? (Double) spinnerThreshold.getValue() : null);
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_checkThresholdActionPerformed
+
+ private void checkGoodRegionActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_checkGoodRegionActionPerformed
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ goodRegion = checkGoodRegion.isSelected();
+ setGoodRegionOptionsVisible(goodRegion);
+ if (goodRegion) {
+ server.setGoodRegion(((Number) spinnerGrThreshold.getValue()).doubleValue(), ((Number) spinnerGrScale.getValue()).doubleValue());
+ } else {
+ server.setGoodRegion(null);
+ }
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_checkGoodRegionActionPerformed
+
+ private void spinnerGrThresholdonChange(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerGrThresholdonChange
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ server.setGoodRegion((Double) spinnerGrThreshold.getValue(), (Double) spinnerGrScale.getValue());
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_spinnerGrThresholdonChange
+
+ private void btFixColormapRangeActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btFixColormapRangeActionPerformed
+ try {
+ updatingColormap = true;
+ ArrayProperties properties = currentFrame.data.getProperties();
+ spinnerMax.setValue(properties.max.intValue());
+ spinnerMin.setValue(properties.min.intValue());
+ buttonManual.setSelected(true);
+ } catch (Exception ex) {
+ showException(ex);
+ } finally {
+ updatingColormap = false;
+ onChangeColormap(null);
+ }
+ }//GEN-LAST:event_btFixColormapRangeActionPerformed
+
+ private void checkSlicingActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_checkSlicingActionPerformed
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ slicing = checkSlicing.isSelected();
+ setSlicingOptionsVisible(slicing);
+ if (slicing) {
+ server.setSlicing((Integer) spinnerSlNumber.getValue(), (Double) spinnerSlScale.getValue(), spinnerSlOrientation.getValue().toString());
+ } else {
+ server.setSlicing(null);
+ }
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_checkSlicingActionPerformed
+
+ private void spinnerSlicingChange(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerSlicingChange
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ server.setSlicing((Integer) spinnerSlNumber.getValue(), (Double) spinnerSlScale.getValue(), spinnerSlOrientation.getValue().toString());
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_spinnerSlicingChange
+
+ private void buttonReticleActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonReticleActionPerformed
+ try {
+ checkReticle();
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonReticleActionPerformed
+
+ private void buttonFitActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonFitActionPerformed
+ try {
+ showFit = buttonFit.isSelected();
+ if (showFit) {
+ renderer.setProfile(Renderer.Profile.None);
+ } else {
+ renderer.removeOverlays(fitOv);
+ fitOv = null;
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonFitActionPerformed
+
+ private void buttonProfileActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonProfileActionPerformed
+ try {
+ showProfile = buttonProfile.isSelected();
+ if (showProfile) {
+ renderer.setProfile(Renderer.Profile.None);
+ } else {
+ renderer.removeOverlays(profileOv);
+ profileOv = null;
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonProfileActionPerformed
+
+ private void buttonMarkerActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonMarkerActionPerformed
+ try {
+ checkMarker(null);
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonMarkerActionPerformed
+
+ private void buttonPauseActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonPauseActionPerformed
+ try {
+ if (!updatingButtons) {
+ setPaused(buttonPause.isSelected());
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonPauseActionPerformed
+
+ private void buttonGrabBackgroundActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonGrabBackgroundActionPerformed
+ try {
+ if (camera != null) {
+ boolean laserOn1 = getLaserState(1);
+ boolean laserOn2 = getLaserState(2);
+ OptionResult ret = null;
+ if (laserOn1 || laserOn2) {
+ if (laserOn1){
+ ret = SwingUtils.showOption(getTopLevel(), "Capture Background", "Do you want to put Bunch 1 laser on delay for capturing background?", OptionType.YesNoCancel);
+ if (ret == OptionResult.No) {
+ laserOn1 = false;
+ }
+ if (ret == OptionResult.Cancel) {
+ return;
+ }
+ }
+ if (laserOn2){
+ ret = SwingUtils.showOption(getTopLevel(), "Capture Background", "Do you want to put Bunch 2 laser on delay for capturing background?", OptionType.YesNoCancel);
+ if (ret == OptionResult.No) {
+ laserOn2= false;
+ }
+ }
+ } else {
+ ret = SwingUtils.showOption(getTopLevel(), "Capture Background", "Do you want to capture background now?", OptionType.OkCancel);
+ }
+
+ if (ret == OptionResult.Cancel) {
+ return;
+ }
+
+ if (laserOn1) {
+ setLaserState(1,false);
+ }
+ if (laserOn2) {
+ setLaserState(2,false);
+ }
+ try {
+ System.out.println("Grabbing background for: " + cameraName);
+ if (server != null) {
+ server.captureBackground(5);
+ } else {
+ camera.captureBackground(5, 0);
+ }
+ } finally {
+ if (laserOn1) {
+ setLaserState(1,true);
+ }
+ if (laserOn2) {
+ setLaserState(2,true);
+ }
+ }
+ SwingUtils.showMessage(getTopLevel(), "Success", "Success capturing background", 5000);
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonGrabBackgroundActionPerformed
+
+ private void buttonSaveActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonSaveActionPerformed
+ try {
+ saveSnapshot();
+ } catch (Exception ex) {
+ Logger.getLogger(getClass().getName()).log(Level.WARNING, null, ex);
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonSaveActionPerformed
+
+ private void buttonStreamDataActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonStreamDataActionPerformed
+ try {
+ showStreamData();
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonStreamDataActionPerformed
+
+ private void buttonSidePanelActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonSidePanelActionPerformed
+ sidePanel.setVisible(buttonSidePanel.isSelected());
+ }//GEN-LAST:event_buttonSidePanelActionPerformed
+
+ private void comboTypeActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_comboTypeActionPerformed
+ try {
+ if (!updatingCameraSelection) {
+ updateCameraList();
+ if ((cameraName != null) && (!cameraName.equals(comboCameras.getSelectedItem()))) {
+ setCamera(null);
+ } else {
+ setCamera(cameraName);
+ }
+ }
+
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ } finally {
+ updateButtons();
+ }
+ }//GEN-LAST:event_comboTypeActionPerformed
+
+ private void comboCamerasActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_comboCamerasActionPerformed
+ try {
+ if (!updatingCameraSelection) {
+ if (!comboCameras.isEnabled()) {
+ throw new Exception("Invalid state");
+ }
+ comboCameras.setEnabled(false);
+ comboType.setEnabled(false);
+ buttonServer.setEnabled(false);
+ buttonDirect.setEnabled(false);
+ final String cameraName = (String) comboCameras.getSelectedItem();
+ new Thread(new Runnable() {
+ @Override
+ public void run() {
+ if (requestCameraListUpdate) {
+ requestCameraListUpdate = false;
+ try {
+ updateCameraList();
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ }
+ }
+ try {
+ setCamera(cameraName.trim().isEmpty() ? null : cameraName);
+ } catch (Exception ex) {
+ ex.printStackTrace();
+ } finally {
+ updateButtons();
+ comboCameras.setEnabled(true);
+ comboType.setEnabled(true);
+ buttonServer.setEnabled(true);
+ buttonDirect.setEnabled(true);
+ }
+ }
+ }).start();
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_comboCamerasActionPerformed
+
+ private void buttonTitleActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonTitleActionPerformed
+ try {
+ manageTitleOverlay();
+ } catch (Exception ex) {
+ showException(ex);
+ } finally {
+ }
+ }//GEN-LAST:event_buttonTitleActionPerformed
+
+ private void buttonScaleActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonScaleActionPerformed
+ try {
+ renderer.setShowColormapScale(buttonScale.isSelected());
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonScaleActionPerformed
+
+ private void checkRotationActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_checkRotationActionPerformed
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ boolean rotation = checkRotation.isSelected();
+ setRotationOptionsVisible(rotation);
+ if (rotation) {
+ spinnerRotationAngleStateChanged(null);
+ } else {
+ server.setRotation(null);
+ }
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_checkRotationActionPerformed
+
+ private void spinnerRotationAngleStateChanged(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerRotationAngleStateChanged
+ try {
+ String mode = String.valueOf(spinnerRotationMode.getValue());
+ server.setRotation(((Number) spinnerRotationAngle.getValue()).doubleValue(),
+ ((Number) spinnerRotationOrder.getValue()).intValue(),
+ mode.equals("constant") ? String.valueOf(spinnerRotationConstant.getValue()): mode);
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }//GEN-LAST:event_spinnerRotationAngleStateChanged
+
+ private void checkAveragingActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_checkAveragingActionPerformed
+ if (!updatingServerControls) {
+ try {
+ if ((server != null) && (server.isStarted())) {
+ setAveragingOptionsVisible(checkAveraging.isSelected());
+ Integer av = spinnerAvMode.getValue().equals("window") ? - (Integer)spinnerAvFrames.getValue() : (Integer)spinnerAvFrames.getValue();
+ setInstanceConfigValue("averaging", checkAveraging.isSelected() ? av : null);
+ }
+ } catch (Exception ex) {
+ showException(ex);
+ updatePipelineControls();
+ }
+ }
+ }//GEN-LAST:event_checkAveragingActionPerformed
+
+ private void spinnerAvModeonChange(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerAvModeonChange
+ checkAveragingActionPerformed(null);
+ }//GEN-LAST:event_spinnerAvModeonChange
+
+ private void spinnerAvFramesStateChanged(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerAvFramesStateChanged
+ checkAveragingActionPerformed(null);
+ }//GEN-LAST:event_spinnerAvFramesStateChanged
+
+ // Variables declaration - do not modify//GEN-BEGIN:variables
+ private javax.swing.JButton btFixColormapRange;
+ private javax.swing.JRadioButton buttonAutomatic;
+ private javax.swing.JRadioButton buttonDirect;
+ private javax.swing.JToggleButton buttonFit;
+ private javax.swing.JRadioButton buttonFullRange;
+ private javax.swing.JButton buttonGrabBackground;
+ private javax.swing.ButtonGroup buttonGroup1;
+ private javax.swing.ButtonGroup buttonGroup2;
+ private javax.swing.ButtonGroup buttonGroup3;
+ private javax.swing.ButtonGroup buttonGroup4;
+ private javax.swing.JRadioButton buttonManual;
+ private javax.swing.JToggleButton buttonMarker;
+ private javax.swing.JToggleButton buttonPause;
+ private javax.swing.JToggleButton buttonProfile;
+ private javax.swing.JToggleButton buttonReticle;
+ private javax.swing.JToggleButton buttonSave;
+ private javax.swing.JToggleButton buttonScale;
+ private javax.swing.JRadioButton buttonServer;
+ private javax.swing.JToggleButton buttonSidePanel;
+ private javax.swing.JButton buttonStreamData;
+ private javax.swing.JToggleButton buttonTitle;
+ private javax.swing.JRadioButton buttonZoom025;
+ private javax.swing.JRadioButton buttonZoom05;
+ private javax.swing.JRadioButton buttonZoom2;
+ private javax.swing.JRadioButton buttonZoomFit;
+ private javax.swing.JRadioButton buttonZoomNormal;
+ private javax.swing.JRadioButton buttonZoomStretch;
+ private javax.swing.JCheckBox checkAveraging;
+ private javax.swing.JCheckBox checkBackground;
+ private javax.swing.JCheckBox checkGoodRegion;
+ private javax.swing.JCheckBox checkHistogram;
+ private javax.swing.JCheckBox checkRotation;
+ private javax.swing.JCheckBox checkSlicing;
+ private javax.swing.JCheckBox checkThreshold;
+ private javax.swing.JComboBox comboCameras;
+ private javax.swing.JComboBox comboColormap;
+ private javax.swing.JComboBox comboFilter;
+ private javax.swing.JComboBox comboScreen;
+ private javax.swing.JComboBox comboType;
+ private javax.swing.Box.Filler filler1;
+ private javax.swing.JLabel jLabel1;
+ private javax.swing.JLabel jLabel3;
+ private javax.swing.JLabel jLabel4;
+ private javax.swing.JLabel jLabel5;
+ private javax.swing.JPanel jPanel2;
+ private javax.swing.JPanel jPanel3;
+ private javax.swing.JPanel jPanel5;
+ private javax.swing.JProgressBar jProgressBar1;
+ private javax.swing.JToolBar.Separator jSeparator6;
+ private javax.swing.JLabel labelAngle;
+ private javax.swing.JLabel labelAvFrames;
+ private javax.swing.JLabel labelAvMode;
+ private javax.swing.JLabel labelConstant;
+ private javax.swing.JLabel labelGrScale;
+ private javax.swing.JLabel labelGrThreshold;
+ private javax.swing.JLabel labelMax;
+ private javax.swing.JLabel labelMin;
+ private javax.swing.JLabel labelMode;
+ private javax.swing.JLabel labelOrder;
+ private javax.swing.JLabel labelSlNumber;
+ private javax.swing.JLabel labelSlOrientation;
+ private javax.swing.JLabel labelSlScale;
+ private javax.swing.JPanel panelCameraSelection;
+ private javax.swing.JPanel panelFilter;
+ private javax.swing.JPanel panelScreen;
+ private javax.swing.JPanel panelScreen2;
+ private javax.swing.JPanel panelSlicing;
+ private ch.psi.pshell.swing.ValueSelection pauseSelection;
+ private ch.psi.pshell.imaging.Renderer renderer;
+ private javax.swing.JPanel sidePanel;
+ private javax.swing.JSpinner spinnerAvFrames;
+ private javax.swing.JSpinner spinnerAvMode;
+ private javax.swing.JSpinner spinnerGrScale;
+ private javax.swing.JSpinner spinnerGrThreshold;
+ private javax.swing.JSpinner spinnerMax;
+ private javax.swing.JSpinner spinnerMin;
+ private javax.swing.JSpinner spinnerRotationAngle;
+ private javax.swing.JSpinner spinnerRotationConstant;
+ private javax.swing.JSpinner spinnerRotationMode;
+ private javax.swing.JSpinner spinnerRotationOrder;
+ private javax.swing.JSpinner spinnerSlNumber;
+ private javax.swing.JSpinner spinnerSlOrientation;
+ private javax.swing.JSpinner spinnerSlScale;
+ private javax.swing.JSpinner spinnerThreshold;
+ private javax.swing.JTextField textState;
+ private javax.swing.JToolBar toolBar;
+ private javax.swing.JPanel topPanel;
+ private ch.psi.pshell.swing.DeviceValuePanel valueFilter;
+ private ch.psi.pshell.swing.DeviceValuePanel valueScreen;
+ // End of variables declaration//GEN-END:variables
+}
diff --git a/plugins/Tst.form b/plugins/Tst.form
new file mode 100644
index 0000000..ff9cfab
--- /dev/null
+++ b/plugins/Tst.form
@@ -0,0 +1,28 @@
+
+
+
diff --git a/plugins/Tst.java b/plugins/Tst.java
new file mode 100644
index 0000000..990227c
--- /dev/null
+++ b/plugins/Tst.java
@@ -0,0 +1,52 @@
+import ch.psi.pshell.ui.Panel;
+import ch.psi.utils.State;
+
+/**
+ *
+ */
+public class Tst extends Panel {
+
+ public Tst() {
+ initComponents();
+ }
+
+ //Overridable callbacks
+ @Override
+ public void onInitialize(int runCount) {
+
+ }
+
+ @Override
+ public void onStateChange(State state, State former) {
+
+ }
+
+ @Override
+ public void onExecutedFile(String fileName, Object result) {
+ }
+
+
+ //Callback to perform update - in event thread
+ @Override
+ protected void doUpdate() {
+ }
+
+ @SuppressWarnings("unchecked")
+ // //GEN-BEGIN:initComponents
+ private void initComponents() {
+
+ javax.swing.GroupLayout layout = new javax.swing.GroupLayout(this);
+ this.setLayout(layout);
+ layout.setHorizontalGroup(
+ layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGap(0, 449, Short.MAX_VALUE)
+ );
+ layout.setVerticalGroup(
+ layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addGap(0, 137, Short.MAX_VALUE)
+ );
+ }// //GEN-END:initComponents
+
+ // Variables declaration - do not modify//GEN-BEGIN:variables
+ // End of variables declaration//GEN-END:variables
+}
diff --git a/plugins/WireScan.form b/plugins/WireScan.form
index 40c2a96..f993b40 100644
--- a/plugins/WireScan.form
+++ b/plugins/WireScan.form
@@ -671,6 +671,9 @@
+
+
+
diff --git a/plugins/WireScan.java b/plugins/WireScan.java
index 01e1cce..3169f41 100644
--- a/plugins/WireScan.java
+++ b/plugins/WireScan.java
@@ -21,8 +21,10 @@ import java.awt.Dimension;
import java.awt.Window;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
+import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
+import java.util.Map;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.swing.DefaultComboBoxModel;
@@ -40,7 +42,7 @@ public class WireScan extends Panel {
boolean parked;
String currentScannner;
- public WireScan() {
+ public WireScan() {
initComponents();
bpmCombos = new JComboBox[]{comboBpm1, comboBpm2, comboBpm3};
blmCombos = new JComboBox[]{comboBlm1, comboBlm2, comboBlm3};
@@ -94,11 +96,8 @@ public class WireScan extends Panel {
comboWireScanner.setSelectedItem(App.getArgumentValue("ws"));
}
comboWireScannerActionPerformed(null);
-
- Device dev = new ChannelDouble (null, "SIN-TIMAST-TMA:Evt-15-Freq-I");
- dev.setMonitored(true);
- dev.initialize();
- panelRepRate.setDevice(dev);
+ updatePanelRepRate();
+
} catch (Exception ex) {
showException(ex);
@@ -106,6 +105,17 @@ public class WireScan extends Panel {
}
+ void updatePanelRepRate() throws Exception{
+ if (panelRepRate.getDevice()!=null){
+ panelRepRate.getDevice().close();
+ }
+ int bunch = (Integer)spinnerBunch.getValue();
+ Device dev = new ChannelDouble (null, (bunch==2) ? "SIN-TIMAST-TMA:Bunch-2-Appl-Freq-RB" : "SIN-TIMAST-TMA:Bunch-1-Appl-Freq-RB");
+ dev.setMonitored(true);
+ dev.initialize();
+ panelRepRate.setDevice(dev);
+ }
+
@Override
public void onStart() {
super.onStart();
@@ -121,7 +131,7 @@ public class WireScan extends Panel {
super.onStop();
}
-
+
@Override
protected void onTimer(){
try{
@@ -602,6 +612,11 @@ public class WireScan extends Panel {
jLabel21.setText("Bunch:");
spinnerBunch.setModel(new javax.swing.SpinnerNumberModel(1, 1, 2, 1));
+ spinnerBunch.addChangeListener(new javax.swing.event.ChangeListener() {
+ public void stateChanged(javax.swing.event.ChangeEvent evt) {
+ spinnerBunchStateChanged(evt);
+ }
+ });
jLabel23.setHorizontalAlignment(javax.swing.SwingConstants.TRAILING);
jLabel23.setText("Vel x (µm/s):");
@@ -1154,7 +1169,7 @@ ChannelDouble channelEndY;
}//GEN-LAST:event_buttonParkActionPerformed
//String caqtdm = "caqtdm -noMsg -stylefile sfop.qss -attach";
- String caqtdm = "caqtdm -noMsg -stylefile sfop.qss";
+ String caqtdm = "startDM -noMsg -stylefile sfop.qss";
ch.psi.pshell.core.Plugin calibrationPlugin;
private void buttonCalibrationActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonCalibrationActionPerformed
try {
@@ -1172,6 +1187,7 @@ ChannelDouble channelEndY;
private void buttonScannerPanelActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonScannerPanelActionPerformed
try {
String cmd = caqtdm + " -macro 'SYS=" + comboWireScanner.getSelectedItem() + "' /sf/common/config/qt/S_DI_WSC_EXPERT.ui";
+ System.out.println(cmd);
Runtime.getRuntime().exec(new String[]{"bash", "-c", cmd.toString()});
} catch (Exception ex) {
showException(ex);
@@ -1232,6 +1248,14 @@ ChannelDouble channelEndY;
// TODO add your handling code here:
}//GEN-LAST:event_comboAdaptiveActionPerformed
+ private void spinnerBunchStateChanged(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerBunchStateChanged
+ try {
+ updatePanelRepRate();
+ } catch (Exception ex) {
+ showException(ex);
+ }
+ }//GEN-LAST:event_spinnerBunchStateChanged
+
// Variables declaration - do not modify//GEN-BEGIN:variables
private javax.swing.JButton buttonAbort;
private javax.swing.JButton buttonCalibration;
diff --git a/script/Alignment/BPM_quad_alignment.py b/script/Alignment/BPM_quad_alignment.py
new file mode 100644
index 0000000..9876bb9
--- /dev/null
+++ b/script/Alignment/BPM_quad_alignment.py
@@ -0,0 +1,110 @@
+import ch.psi.pshell.epics.Positioner as Positioner
+
+dry_run = False
+do_elog = True
+is_panel = get_exec_pars().source != CommandSource.ui # must be check before run
+
+run("CPython/wrapper")
+#Parameters
+if is_panel:
+ MCR1 = args[0]
+else:
+ U = "X"
+ MQUA = "SATMA01-MQUA050"
+ MCR1 = {"X": "SATCB01-MCRX430", "Y": "SATCB01-MCRY430" }
+ BPM1 = {"X": "SARCL01-DBPM150:X1", "Y": "SARCL01-DBPM150:Y1" }
+ BPM2 = {"X": "SARCL02-DBPM110:X1", "Y": "SARCL02-DBPM110:Y1" }
+ dC = 2.0
+ dK = 0.05
+ step = 10
+ nb = 5
+ lat = 0.0
+ plt = plot(None, title="Output")[0]
+
+#Plot setup
+plt.clear()
+plt.removeMarker(None)
+plt.setStyle(plt.Style.ErrorXY)
+plt.addSeries(LinePlotErrorSeries("run0", Color.red))
+plt.addSeries(LinePlotErrorSeries("run1", Color.yellow))
+plt.addSeries(LinePlotErrorSeries("run2", Color.green))
+plt.getAxis(plt.AxisId.X).setLabel("BPM1 (mm)")
+plt.getAxis(plt.AxisId.Y).setLabel("BPM2 (mm)")
+plt.setLegendVisible(True)
+
+#Creating Phase positioner
+if dry_run:
+ kick1 = Positioner("kick1", "SATCB01-MCRX430:I-SET", "SATCB01-MCRX430:I-READ")
+ quad = Positioner("quad", "SATMA01-MQUA050:K1L-SET", "SATMA01-MQUA050:K1L-READ")
+else:
+ kick1 = Positioner("kick1", MCR1[U] + ":I-SET", MCR1[U] + ":I-READ")
+ quad = Positioner("quad", MQUA + ":K1L-SET", MQUA + ":K1L-READ")
+quad.config.minValue = -2.0
+quad.config.maxValue = 2.0
+kick1.initialize()
+quad.initialize()
+kick1_ini = kick1.read()
+quad_ini = quad.read()
+start = kick1_ini - dC / 2
+stop = kick1_ini + dC / 2
+
+#Creating averagers
+X1 = "ca://" + BPM1[U]
+X2 = "ca://" + BPM2[U]
+X1_averager = create_averager(X1, nb, -1) # -1 event based, waits for the next value
+X2_averager = create_averager(X2, nb, -1) # ca:// it comes from epics channels
+X2_averager.monitored = True # not blocking, will return last nb values
+
+#Record callback: uptate of output plot
+def after_sample(record, scan):
+ global plt,i
+ X1_mean, X1_stdev = record.values[0].mean, record.values[0].stdev
+ X2_mean, X2_stdev = record.values[1].mean, record.values[1].stdev
+ plt.getSeries(i).appendData(X1_mean, X2_mean, X1_stdev, X2_stdev)
+
+#The scan loop
+try:
+ data = []
+ i = 0
+ for K1L in (quad_ini, quad_ini - dK, quad_ini + dK):
+ kick1.write(start)
+ quad.write(K1L)
+ time.sleep(2.0)
+ r = lscan(kick1, [X1_averager, X2_averager], start, stop, step , latency=lat, after_read = after_sample)
+ data.append({"K1L":K1L,"scan":r})
+ i = i + 1
+finally:
+ kick1.write(kick1_ini)
+ kick1.close()
+ quad.write(quad_ini)
+ quad.close()
+
+#Fitting and plotting
+P = []
+for i in range(len(data)):
+ x = data[i]["scan"].getReadable(0)
+ y = data[i]["scan"].getReadable(1)
+ (p, x_fit, y_fit, R2) = linfit(x, y)
+ P.append(p)
+ plt.addSeries(LinePlotErrorSeries("Fit"+str(i), plt.getSeries(i).color))
+ plt.getSeries(i+3).setData(x_fit, y_fit)
+ plt.getSeries(i+3).setPointsVisible(False)
+a, b = P[1][0], P[1][1] #second line +K
+c, d = P[2][0], P[2][1] #third line -K
+ui = (d - b)/(a - c) if a != c else None
+
+#Elog entry
+if do_elog:
+ if get_option("Generated data file:\n" + get_exec_pars().path +"\n\n" + "Save to ELOG?", "YesNo") == "Yes":
+ title = "BPM_Quad_scan"
+ log_msg = "Data file: " + get_exec_pars().path + "\n\n"
+ log_msg = log_msg + "MQUA: " + MQUA + "\n"
+ log_msg = log_msg + "BPM1: " + BPM1[U] + "\n"
+ log_msg = log_msg + "BPM2: " + BPM2[U] + "\n"
+ log_msg = log_msg + "MQUA center: " + str(ui) + "\n"
+ sleep(0.1) #Give some time to plot to be finished - it is not sync with acquisition
+ file_name = os.path.abspath(get_context().setup.getContextPath() + "/BPM_Quad_Plot.png")
+ plt.saveSnapshot(file_name , "png")
+ elog(title, log_msg, [file_name,])
+
+set_return(ui)
diff --git a/script/Alignment/Gun_solenoid_alignment.py b/script/Alignment/Gun_solenoid_alignment.py
index fa48c8b..84080a1 100755
--- a/script/Alignment/Gun_solenoid_alignment.py
+++ b/script/Alignment/Gun_solenoid_alignment.py
@@ -5,7 +5,7 @@
# Procedure:
# switch off all the magnets between the gun solenoid and the screen or BPM used for the measurement
- # change the current of the gun soleoid
+ # change the current of the gun solenoid
# look at the centroid position (BPM or screen) downstream of the gun.
import datetime
@@ -16,6 +16,7 @@ is_panel = get_exec_pars().source != CommandSource.ui #Must be checked before c
camera_name = "simulation" if dry_run else "SINEG01-DSCR190"
bpm_name = "SINEG01-DBPM340"
use_good_region=False
+use_screen_panel_stream = True
magnets = ["SINEG01-MCRX120","SINEG01-MCRY120",
"SINEG01-MQUA140","SINEG01-MQSK150",
"SINEG01-MCRX160","SINEG01-MCRY160",
diff --git a/script/Alignment/Laser_gun_alignment.py b/script/Alignment/Laser_gun_alignment.py
index e9bb5ae..b8a5ca6 100755
--- a/script/Alignment/Laser_gun_alignment.py
+++ b/script/Alignment/Laser_gun_alignment.py
@@ -13,6 +13,7 @@ import datetime
do_elog = True
dry_run = False
+use_screen_panel_stream = True
is_panel = get_exec_pars().source != CommandSource.ui #Must be checked before callin "run"
camera_name = "simulation" if dry_run else "SINEG01-DSCR190"
bpm_name = "SINEG01-DBPM340"
diff --git a/script/CPython/linfit.py b/script/CPython/linfit.py
new file mode 100644
index 0000000..85dd45b
--- /dev/null
+++ b/script/CPython/linfit.py
@@ -0,0 +1,16 @@
+import numpy as np
+
+def linfit(x, y):
+ """
+ Return linear fit
+ """
+ p = np.polyfit(x, y, 1)
+ f = np.poly1d(p)
+ x_fit = np.linspace(min(x), max(x), 100)
+ y_fit = f(x_fit)
+ yhat = f(x)
+ ybar = np.sum(y)/len(y)
+ ssreg = np.sum((yhat - ybar)**2)
+ sstot = np.sum((y - ybar)**2)
+ R2 = ssreg / sstot
+ return (p, x_fit, y_fit, R2)
\ No newline at end of file
diff --git a/script/CPython/wrapper.py b/script/CPython/wrapper.py
index d9e1759..94534b6 100644
--- a/script/CPython/wrapper.py
+++ b/script/CPython/wrapper.py
@@ -12,6 +12,10 @@ def gfitoff(x, y, off=None, amp=None, com=None, sigma=None):
ret = call_jep("CPython/gfitoff", "gfitoff", [to_npa(x), to_npa(y), off, amp, com, sigma])
return ret if ret is None or is_list(ret) else ret.data
+def linfit(x, y):
+ ret = call_jep("CPython/linfit", "linfit", [to_npa(x),to_npa(y)])
+ return (ret[0].data, ret[1].data, ret[2].data, ret[3])
+
diff --git a/script/Correlation/Correlation2.py b/script/Correlation/Correlation2.py
index 5182d3d..53df812 100644
--- a/script/Correlation/Correlation2.py
+++ b/script/Correlation/Correlation2.py
@@ -11,17 +11,21 @@ TYPE_CHANNEL = 0
TYPE_STREAM = 1
TYPE_CAMERA= 2
+INVOKE_PLOT_UPDATES = True
+
if get_exec_pars().source == CommandSource.ui:
- dx = "SINDI01-RLLE-STA:SLAVE1-CPUTIMER"
- #dx = "SLG-LCAM-C042 x_rms"
- dxtype = TYPE_STREAM
+ dx = "SINEG01-DICT215:B1_CHARGE"
+ #dx = "SLG-LCAM-C042 x_rms"
dxtype = TYPE_CHANNEL
+ dxtype = TYPE_STREAM
#dxtype = TYPE_CAMERA
#dy = "SINDI01-RLLE-STA:SLAVE1-DLTIMER"
dy = "SLG-LCAM-C042 y_rms"
- dytype = TYPE_STREAM
+
dytype = TYPE_CHANNEL
dytype = TYPE_CAMERA
+ dy = "SINEG01-DICT215:B1_CHARGE"
+ dytype = TYPE_STREAM
interval = 0.10
window = 40
p = plot(None)[0]
@@ -161,66 +165,77 @@ try:
y=bsdata.pop(0)
elif dytype==TYPE_CAMERA:
y=dy.read()
-
- sd.appendData(x, y)
- if len(sd.x) > window:
- #Remove First Element
- sd.token.remove(0)
- ax = sd.x
- ay = sd.y
- if len(ax)>2:
- x1, x2 = min(ax), max(ax)
- res = (x2-x1)/100
- if x1!=x2:
- #Display correlation
- corr= PearsonsCorrelation().correlation(to_array(ax,'d'), to_array(ay,'d'))
- s = "Correlation=" + str(round(corr,4))
- #print s
- if get_exec_pars().source == CommandSource.ui:
- if marker is not None:
- p.removeMarker(marker)
- marker = p.addMarker(x2+res, p.AxisId.X, s, p.getBackground())
- marker.setLabelPaint(STDOUT_COLOR)
- if linear_fit:
- #Calculate, print and plot linear fit
- pars_lin = (a0,a1) = fit_polynomial(ay, ax, 1)
- #print "Fit lin a1:" , a1, " a0:",a0
- y1 = poly(x1, pars_lin)
- y2 = poly(x2, pars_lin)
- plot_line(p, x1, y1, x2, y2, width = 2, color = Color.BLUE, name = "Fit Linear")
- if quadratic_fit:
- #Calculate, print and plot quadratic fit
- pars_quad = (a0,a1,a2) = fit_polynomial(ay, ax, 2)
- #print "Fit quad a2:" , a2, "a1:" , a1, " a0:",a0
- fitted_quad_function = PolynomialFunction(pars_quad)
- ax = frange(x1, x2, res, True)
- plot_function(p, fitted_quad_function, "Fit Quadratic", ax, color=Color.GREEN)
-
- peak = None
- peaks = calculate_peaks(fitted_quad_function, x1, x2, positive=True)
- if len(peaks)>0:
- peak = peaks[0]
- pos_peak = str(round(peak,4))
- peak_str = "Positive peak: " + pos_peak
- else:
- peaks = calculate_peaks(fitted_quad_function, x1, x2, positive=False)
+
+ def update():
+ global marker, peak_marker, corr, pars_lin, pars_quad, pos_peak, neg_peak, stop_exec
+ sd.appendData(x, y)
+ if len(sd.x) > window:
+ #Remove First Element
+ sd.token.remove(0)
+ ax = sd.x
+ ay = sd.y
+ if len(ax)>2:
+ x1, x2 = min(ax), max(ax)
+ res = (x2-x1)/100
+ if x1!=x2:
+ #Display correlation
+ corr= PearsonsCorrelation().correlation(to_array(ax,'d'), to_array(ay,'d'))
+ s = "Correlation=" + str(round(corr,4))
+ #print s
+ if get_exec_pars().source == CommandSource.ui:
+ if marker is not None:
+ p.removeMarker(marker)
+ marker = p.addMarker(x2+res, p.AxisId.X, s, p.getBackground())
+ marker.setLabelPaint(STDOUT_COLOR)
+ if linear_fit:
+ #Calculate, print and plot linear fit
+ pars_lin = (a0,a1) = fit_polynomial(ay, ax, 1)
+ #print "Fit lin a1:" , a1, " a0:",a0
+ y1 = poly(x1, pars_lin)
+ y2 = poly(x2, pars_lin)
+ plot_line(p, x1, y1, x2, y2, width = 2, color = Color.BLUE, name = "Fit Linear")
+ if quadratic_fit:
+ #Calculate, print and plot quadratic fit
+ pars_quad = (a0,a1,a2) = fit_polynomial(ay, ax, 2)
+ #print "Fit quad a2:" , a2, "a1:" , a1, " a0:",a0
+ fitted_quad_function = PolynomialFunction(pars_quad)
+ ax = frange(x1, x2, res, True)
+ plot_function(p, fitted_quad_function, "Fit Quadratic", ax, color=Color.GREEN)
+
+ peak = None
+ peaks = calculate_peaks(fitted_quad_function, x1, x2, positive=True)
if len(peaks)>0:
peak = peaks[0]
- neg_peak = str(round(peak,4))
- peak_str = "Negative peak: " + neg_peak
+ pos_peak = str(round(peak,4))
+ peak_str = "Positive peak: " + pos_peak
else:
- pos_peak = neg_peak = None
- if get_exec_pars().source == CommandSource.ui:
- if peak_marker is not None:
- p.removeMarker(peak_marker)
- if peak is not None:
- peak_marker = p.addMarker(peak, p.AxisId.X, peak_str, Color(0,128,0))
-
+ peaks = calculate_peaks(fitted_quad_function, x1, x2, positive=False)
+ if len(peaks)>0:
+ peak = peaks[0]
+ neg_peak = str(round(peak,4))
+ peak_str = "Negative peak: " + neg_peak
+ else:
+ pos_peak = neg_peak = None
+ if get_exec_pars().source == CommandSource.ui:
+ if peak_marker is not None:
+ p.removeMarker(peak_marker)
+ if peak is not None:
+ peak_marker = p.addMarker(peak, p.AxisId.X, peak_str, Color(0,128,0))
+ if INVOKE_PLOT_UPDATES:
+ invoke(update, False)
+ else:
+ update()
+
if stop_exec == True:
stop_exec = False
break
if bs != True:
- time.sleep(interval)
+ time.sleep(interval)
+except KeyboardInterrupt:
+ pass
finally:
for dev in instances:
- dev.close()
\ No newline at end of file
+ try:
+ dev.close()
+ except:
+ pass
\ No newline at end of file
diff --git a/script/Devices/Elements.py b/script/Devices/Elements.py
index b09b2cd..76c04ba 100644
--- a/script/Devices/Elements.py
+++ b/script/Devices/Elements.py
@@ -126,7 +126,7 @@ elements = (
(DBLM, "SATDI01-DBLM225", 349.5613),
(DBPM, "SATDI01-DBPM240", 352.1997),
(DBPM, "SATDI01-DBPM270", 355.1797),
- (DWSC, "SATDI01-DWSC290", 356.4797),
+ #(DWSC, "SATDI01-DWSC290", 356.4797),
(DBPM, "SATDI01-DBPM320", 357.0907),
(DBPM, "S30CB07-DBPM420", 358.4150),
(DBPM, "SATCB01-DBPM220", 361.5357),
@@ -168,6 +168,8 @@ elements = (
(DBPM, "SARMA02-DBPM020", 490.0107),
(DBPM, "SARMA02-DBPM040", 492.0597),
(DWSC, "SARMA02-DWSC060", 492.3767),
+ (DWSC, "SATBD01-DWSC110", 493.078),
+ (DBLM, "SATBD01-DBLM205", 498.7),
(DBPM, "SARMA02-DBPM110", 496.8097),
(DBLM, "SARUN01-DBLM065", 497.8392),
(DBPM, "SARUN01-DBPM070", 501.5597),
@@ -268,7 +270,9 @@ def get_wire_scanners_bpms(wire_scan):
if len(ret) > 0:
return [ret[0],element[1]]
last = element[1]
- return None
+ if ret is not None and len(ret)==1:
+ ret.append(None)
+ return ret
def get_wire_scanners_blms(wire_scan):
@@ -401,4 +405,4 @@ def set_wire_scan_range(wsc, wire, start, end):
start = min (max(start, -2000), 2000.0)
end = min (max(end, -2000), 2000.0)
caput((wsc + ":" + sel[wire] +"_START_SP"), start)
- caput((wsc + ":" + sel[wire] +"_END_SP"), end)
\ No newline at end of file
+ caput((wsc + ":" + sel[wire] +"_END_SP"), end)
diff --git a/script/Diagnostics/BlmGainScan_1406.py b/script/Diagnostics/BlmGainScan_1406.py
index ea7381b..3165552 100644
--- a/script/Diagnostics/BlmGainScan_1406.py
+++ b/script/Diagnostics/BlmGainScan_1406.py
@@ -16,6 +16,7 @@ ATT_SP = 15.0 #3.0,6.0,9.0,12.0,15.0
RANGE = [0.5, 1.1]
STEP_SIZE = 0.05
SETTLING_TIME = 3
+BUNCH = 1
SIMULATION = False
do_elog = True
@@ -41,7 +42,7 @@ for att in attenuators:
sensors = []
line_plots = []
st = Stream("pulse_id", dispatcher)
-st.setFilter("SIN-CVME-TIFGUN-EVR0:BEAMOK == 1")
+st.setFilter(get_beam_ok_channel(BUNCH) + " == 1")
for i in range(len(BLMS)):
blm = Scalar("blm" + str(i+1), st, BLMS[i] + ":B1_LOSS", 1, 0)
av = create_averager(blm, SAMPLES, interval = -1)
@@ -72,7 +73,6 @@ for i in range(len(BPMS)):
sensors.append(av1.samples)
line_plots.append(av1.samples)
-#Scalar("beam_ok" , st, "SIN-CVME-TIFGUN-EVR0:BEAMOK" , 1, 0)
st.initialize()
st.start()
st.waitCacheChange(5000) #Wait stream be running before starting scan
diff --git a/script/Diagnostics/BlmGainScan_v2.py b/script/Diagnostics/BlmGainScan_v2.py
index 79becc7..9fd0ef4 100644
--- a/script/Diagnostics/BlmGainScan_v2.py
+++ b/script/Diagnostics/BlmGainScan_v2.py
@@ -12,6 +12,7 @@ ATTENUATORS = ["SINDI02-DBLM084:M06-1-ATT2-VAL", "SINDI02-DBLM084:M06-2-ATT2-VAL
RANGE = [0.5, 1.1]
STEP_SIZE = 0.1
SETTLING_TIME = 0.5
+BUNCH = 1
SIMULATION = False
do_elog = True
@@ -37,7 +38,7 @@ for i in range(len(ATTENUATORS)):
sensors = []
line_plots = []
st = Stream("pulse_id", dispatcher)
-st.setFilter("SIN-CVME-TIFGUN-EVR0:BEAMOK == 1")
+st.setFilter(get_beam_ok_channel(BUNCH) + " == 1")
for i in range(len(BLMS)):
blm = Scalar("blm" + str(i+1), st, BLMS[i] + ":B1_LOSS", 1, 0)
av = create_averager(blm, SAMPLES, interval = -1)
@@ -61,7 +62,6 @@ for i in range(len(BPMS)):
sensors.append(av1.samples)
line_plots.append(av1.samples)
-#Scalar("beam_ok" , st, "SIN-CVME-TIFGUN-EVR0:BEAMOK" , 1, 0)
st.initialize()
st.start()
st.waitCacheChange(10000) #Wait stream be running before starting scan
diff --git a/script/Diagnostics/Blm_WF_Plot.py b/script/Diagnostics/Blm_WF_Plot.py
index 8f76bc3..f66fdd9 100644
--- a/script/Diagnostics/Blm_WF_Plot.py
+++ b/script/Diagnostics/Blm_WF_Plot.py
@@ -1,5 +1,5 @@
st = Stream("st1",dispatcher)
-st.setFilter("SIN-CVME-TIFGUN-EVR0:BEAMOK == 1")
+st.setFilter(get_beam_ok_channel(bunch=1) + " == 1")
c = "SARCL02-DBLM135:LOSS_SIGNAL_RAW"
st.addWaveform(c, c, 1, 2048)
diff --git a/script/Diagnostics/ICTScan_1406.py b/script/Diagnostics/ICTScan_1406.py
index 7aa25fa..64507d1 100644
--- a/script/Diagnostics/ICTScan_1406.py
+++ b/script/Diagnostics/ICTScan_1406.py
@@ -16,6 +16,7 @@ ROT = ["SLGTV-LAPP:SIZE-SET"] # IRIS
RANGE = [4.4, 2.0] # IRIS range
STEP_SIZE = 0.1 # IRIS Step size
SETTLING_TIME = 3
+BUNCH = 1
SIMULATION = False
do_elog = True
@@ -28,7 +29,7 @@ for i in range(len(ROT)):
sensors = []
line_plots = []
st = Stream("pulse_id", dispatcher)
-st.setFilter("SIN-CVME-TIFGUN-EVR0:BEAMOK == 1")
+st.setFilter(get_beam_ok_channel(BUNCH) + " == 1")
for i in range(len(ICTS)):
ict = Scalar("ict" + str(i+1), st, ICTS[i] + ":B1_CHARGE", 1, 0)
av = create_averager(ict, SAMPLES, interval = -1)
@@ -66,7 +67,6 @@ for i in range(len(ICTV)):
add_device(av2, True)
#sensors.append(ictv)
-#Scalar("beam_ok" , st, "SIN-CVME-TIFGUN-EVR0:BEAMOK" , 1, 0)
st.initialize()
st.start()
st.waitCacheChange(5000) #Wait stream be running before starting scan
diff --git a/script/Diagnostics/ICT_timing_fine.py b/script/Diagnostics/ICT_timing_fine.py
index 4aee031..8db25b9 100644
--- a/script/Diagnostics/ICT_timing_fine.py
+++ b/script/Diagnostics/ICT_timing_fine.py
@@ -2,8 +2,8 @@ import ch.psi.pshell.epics.ChannelDouble as ChannelDouble
dry_run = False
do_elog = True
-base_name = "SARBD01-DICT599" # SINEG01-DICT009 S10DI01-DICT113 SARMA01-DICT482 SARBD01-DICT599 SATDI01-DICT344
-dev_name = "SARBD01-DICT030" # SINEG01-DICT215 S10DI01-DICT025 SARMA01-DICT090 SARBD01-DICT030 SATDI01-DICT020
+base_name = "SATBD02-DICT499" # SINEG01-DICT009 S10DI01-DICT113 SARMA01-DICT482 SARBD01-DICT599 SATDI01-DICT344
+dev_name = "SATBD02-DICT020" # SINEG01-DICT215 S10DI01-DICT025 SARMA01-DICT090 SARBD01-DICT030 SATDI01-DICT020
run("CPython/wrapper")
@@ -22,8 +22,8 @@ V.initialize()
t0 = t.read()
-start = 5
-stop = 10
+start = 2.2
+stop = 12
step = 0.1
nb = 5
lat = 0.150
diff --git a/script/Diagnostics/ICT_timing_rough.py b/script/Diagnostics/ICT_timing_rough.py
index 51fac3a..1004d3d 100644
--- a/script/Diagnostics/ICT_timing_rough.py
+++ b/script/Diagnostics/ICT_timing_rough.py
@@ -2,8 +2,8 @@ import ch.psi.pshell.epics.ChannelDouble as ChannelDouble
dry_run = False
do_elog = True
-base_name = "SATDI01-DICT344" # SINEG01-DICT009 S10DI01-DICT113 SARMA01-DICT482 SARBD01-DICT599
-dev_name = "SATDI01-DICT020" # SINEG01-DICT215 S10DI01-DICT025 SARMA01-DICT090 SARBD01-DICT030
+base_name = "SATBD02-DICT499" # SINEG01-DICT009 S10DI01-DICT113 SARMA01-DICT482 SARBD01-DICT599
+dev_name = "SATBD02-DICT020" # SINEG01-DICT215 S10DI01-DICT025 SARMA01-DICT090 SARBD01-DICT030
if dry_run:
t = ChannelDouble("fine delay (us)", "SINEG01-DICT215:Pul1-Delay-SP-SIM")
@@ -20,9 +20,9 @@ V.initialize()
t0 = t.read()
-start = 1002.170
+start = 1001.000
stop = 1002.200
-step = 0.001
+step = 0.01
nb = 5
lat = 0.150
diff --git a/script/Diagnostics/WireScan.py b/script/Diagnostics/WireScan.py
index b013349..559cdcc 100644
--- a/script/Diagnostics/WireScan.py
+++ b/script/Diagnostics/WireScan.py
@@ -38,7 +38,7 @@ INCREMENT_FACTOR = 0.5
SCAN_RANGE_FACTOR = 6
MAX_RANGE_STEP = 300
-SET_BLM_WS_MODE = True
+SET_BLM_WS_MODE = False
SET_BLM_WS_SETTLING_TIME = 2.0
SET_BLM_WS_BS_READBACK_TIMEOUT = 10000 #ms
@@ -71,7 +71,7 @@ if scan_range is None or len(scan_range) !=4:
caget(prefix+":W1Y_END_SP", 'd') ]
-rr = get_repetition_rate()
+rr = get_repetition_rate(bunch)
velocity_x = abs(scan_range[1]-scan_range[0])*rr/n_shot
velocity_y = abs(scan_range[3]-scan_range[2])*rr/n_shot
@@ -102,7 +102,7 @@ for i in range (len(bpms)):
if SET_BLM_WS_MODE and (len(blms)>0):
channels.append(("blm1_ws_mode", blms[0] + ":WS_RUNNING"))
-channels.append(("beam_ok", "SIN-CVME-TIFGUN-EVR0:BEAMOK"))
+channels.append(("beam_ok", get_beam_ok_channel(bunch)))
#Metadata
@@ -131,9 +131,9 @@ for retry in range(STREAM_CREATION_RETRIES):
st = Stream("pulse_id", dispatcher)
for c in channels:
if c[1].endswith("LOSS_SIGNAL_RAW"):
- st.addWaveform(c[0], c[1], int(100.0 / get_repetition_rate()), 0)
+ st.addWaveform(c[0], c[1], int(100.0 / rr), 0)
else:
- st.addScalar(c[0], c[1], int(100.0 / get_repetition_rate()), 0)
+ st.addScalar(c[0], c[1], int(100.0 / rr), 0)
st.initialize()
st.start()
st.waitCacheChange(10000) #Wait stream be running before starting scan
@@ -442,7 +442,7 @@ def get_scan_time():
ret += abs(scan_range[2] - scan_range[3])/velocity_y #Y SCAN
ret += 2.0 #ACC/DEC
ret *= cycles
- ret += bkgrd * (1.0/get_repetition_rate()) #BACK
+ ret += bkgrd * (1.0/rr) #BACK
print "Scan time = " + str(ret),
ret = ret * 2.0 + 10.0 #Tolernces
print "; with tolerance = " + str(ret),
@@ -451,7 +451,8 @@ def get_scan_time():
print "Starting scan..."
try:
if SET_BLM_WS_MODE and len(blms)>0:
- start_blm_ws(blms[0], get_scan_time())
+ for i in range(len(blms)):
+ start_blm_ws(blms[i], get_scan_time())
#TODO: Wait for stream variable indicate bllm is in ws mode
print "Waiting for WS mode..."
#time.sleep(SET_BLM_WS_SETTLING_TIME)
@@ -460,7 +461,7 @@ try:
do_background()
stream_filter = scanner.curr_cycl.get_name() + ">0"
if filter_beam_ok:
- stream_filter = stream_filter + " AND SIN-CVME-TIFGUN-EVR0:BEAMOK == 1"
+ stream_filter = stream_filter + " AND " + get_beam_ok_channel(bunch) + " == 1"
st.setFilter(stream_filter)
print "Executing scan 1..."
do_scan(0)
diff --git a/script/Diagnostics/WireScanCalibration.py b/script/Diagnostics/WireScanCalibration.py
index 480909b..0eca935 100644
--- a/script/Diagnostics/WireScanCalibration.py
+++ b/script/Diagnostics/WireScanCalibration.py
@@ -19,6 +19,7 @@ n_shot = args[5] if is_panel else 200
saturation = args[6] if is_panel else 19950 / 10 #S10DI01-DBLM113:AL1-WS-PMT-GAIN
scan_range_factor = args[7] if is_panel else 6.0
initial_gain = args[8] if is_panel else 0.6
+bunch = 1
ws_blm = get_wire_scanners_blms(ws_prefix )[0]
@@ -40,9 +41,9 @@ print "Setting gain=", initial_gain
#Calculate speed
x_min, x_max = range_start, range_end
-#rr = get_repetition_rate()
+rr = get_repetition_rate(bunch)
#ws_speed = (x_max- x_min)*rr/n_shot
-args = [ ws_prefix , ws_wire, [x_min, x_max, x_min, x_max], 1, n_shot, [], [ws_blm], 10, plt, False,1,0]
+args = [ ws_prefix , ws_wire, [x_min, x_max, x_min, x_max], 1, n_shot, [], [ws_blm], 10, plt, False,bunch,0, True]
ret = run("Diagnostics/WireScan", args)
[rms_com, rms_sigma, com, sigma, pos_path, path] = ret
@@ -56,7 +57,7 @@ print "--------------- Optimize gain --------------- "
#Need 30s for 25Hz at full gain range. Have a 2x factor.
-start_blm_ws(ws_blm, 2*7.5*(100/get_repetition_rate()))
+start_blm_ws(ws_blm, 2*7.5*(100/rr))
ws_info = WireScanInfo("ws_info", ws_prefix )
motor_pos= ws_info.get_motor_pos(com, ws_wire)
@@ -74,9 +75,9 @@ set_status("Creating stream for gain search..." )
st = Stream("blm_stream", dispatcher)
ch_int = ws_blm + ":B1_LOSS"
ch_raw = ws_blm + ":LOSS_SIGNAL_RAW"
-st.addScalar(ch_int, ch_int, int(100.0 / get_repetition_rate()), 0)
-st.addWaveform(ch_raw, ch_raw, int(100.0 / get_repetition_rate()), 0)
-st.addScalar("blm1_ws_mode", ws_blm + ":WS_RUNNING", int(100.0 / get_repetition_rate()), 0)
+st.addScalar(ch_int, ch_int, int(100.0 / rr), 0)
+st.addWaveform(ch_raw, ch_raw, int(100.0 / rr), 0)
+st.addScalar("blm1_ws_mode", ws_blm + ":WS_RUNNING", int(100.0 / rr), 0)
st.initialize()
st.start()
st.waitCacheChange(10000) #Wait stream be running before starting scan
diff --git a/script/GenericScans/191007_MKscan.py b/script/GenericScans/191007_MKscan.py
new file mode 100644
index 0000000..40bd246
--- /dev/null
+++ b/script/GenericScans/191007_MKscan.py
@@ -0,0 +1,28 @@
+import ch.psi.pshell.epics.ChannelDouble as ChannelDouble
+A1 = ChannelDouble("actname", "S20SY02-MKAC040:I-SET")
+S1 = ChannelDouble("sensname", "SARFE10-PBPG050:HAMP-INTENSITY-AVG")
+A1.initialize()
+S1.initialize()
+A1_init = A1.read()
+A1i = 244.58
+A1f = 254.82
+step = 0.5122
+lat1 = 0.11
+lat2 = 1.0
+nav = 300
+plt = plot(None, title="Output")[0]
+plt.clear()
+plt.setStyle(plt.Style.ErrorY)
+plt.addSeries(LinePlotErrorSeries("Sensor1", Color.red))
+def after_sample(record, scan):
+ plt.getSeries(0).appendData(record.positions[0], record.values[0].mean, record.values[0].stdev)
+try:
+ S1_averager = create_averager(S1, nav, lat1)
+ A1.write(A1i)
+ time.sleep(2.0)
+ r = lscan(A1, (S1_averager), A1i, A1f, step, latency=lat2, after_read = after_sample)
+ Act1 = r.getPositions(0)
+finally:
+ A1.write(A1_init)
+ A1.close()
+ S1.close()
\ No newline at end of file
diff --git a/script/RFscan/GunEnergyScan.py b/script/RFscan/GunEnergyScan.py
index ab25774..3c5e47b 100644
--- a/script/RFscan/GunEnergyScan.py
+++ b/script/RFscan/GunEnergyScan.py
@@ -60,9 +60,9 @@ phase0 = phase.read() % 360
#Camera setup
if USE_SCREEN_PANEL:
- cam_server.start(camera_name+"_sp1", True) #True for shared pipeline
+ cam_server.start(camera_name+"_sp1", True) # shared pipeline
else:
- cam_server.start(camera_name)
+ cam_server.start(camera_name) # generic pipeline
wait_cam_server_message()
x = cam_server.stream.getChild("x_center_of_mass")
dx = cam_server.stream.getChild("x_rms")
@@ -72,7 +72,7 @@ cam_server.setBackgroundSubtraction(False)
#Creating averagers
x_averager = create_averager(x, nb, -1) # -1 event based, waits for the next value
dx_averager = create_averager(dx, nb, -1)
-dx_averager.monitored = True # not blocking, will return last nb values
+dx_averager.monitored = True # not blocking, will return last nb values
#Record callback: uptate of output plot
def after_sample(record, scan):
@@ -144,16 +144,21 @@ if do_elog:
log_msg = "Data file: " + get_exec_pars().path + "\n\n"
log_msg = log_msg + "Laser: " + Laser + "\n"
if Laser == "Alcor":
- log_msg = log_msg + "Energy plate Alcor: %0.2f" % caget("SLGTH01-LMRM-M074:MOT.RBV") + " deg \n"
+ log_msg = log_msg + "Energy plate Alcor: %0.2f" % caget("SLAUV01-LATN100:MOT.RBV") + " deg \n"
elif Laser == "Jaguar":
- log_msg = log_msg + "Energy plate Jaguar: %0.2f" % caget("SLGJG-LMRM-M031:MOT.RBV") + " deg \n"
+ log_msg = log_msg + "Energy plate Jaguar: %0.2f" % caget("SLJUV01-LATN100:MOT.RBV") + " deg \n"
elif Laser == "Both":
- log_msg = log_msg + "Energy plate Alcor: %0.2f" % caget("SLGTH01-LMRM-M074:MOT.RBV") + " deg \n"
- log_msg = log_msg + "Energy plate Jaguar: %0.2f" % caget("SLGJG-LMRM-M031:MOT.RBV") + " deg \n"
- if caget("SLGTV-LMTO-M053:MOT-ACT-POS") == "IRIS":
- log_msg = log_msg + "Collimator: IRIS %0.2f" % caget("SLGTV-LAPP:SIZE-GET") + " mm \n"
+ log_msg = log_msg + "Energy plate Alcor: %0.2f" % caget("SLAUV01-LATN100:MOT.RBV") + " deg \n"
+ log_msg = log_msg + "Energy plate Jaguar: %0.2f" % caget("SLJUV01-LATN100:MOT.RBV") + " deg \n"
+ if caget("SLAUV01-LAPT100:IRIS-POS-GET") == "IRIS":
+ log_msg = log_msg + "Collimator Alcor: IRIS %0.2f" % caget("SLAUV01-LAPT100:SIZE-GET") + " mm \n"
else:
- log_msg = log_msg + "Collimator: " + str(caget("SLGTV-LMTO-M053:MOT-ACT-POS")) + "\n"
+ log_msg = log_msg + "Collimator Alcor: " + str(caget("SLAUV01-LAPT100:IRIS-POS-GET")) + "\n"
+ if caget("SLMUV01-LAPT100:IRIS-POS-GET") == "IRIS":
+ log_msg = log_msg + "Collimator Mizar: IRIS %0.2f" % caget("SLMUV01-LAPT100:SIZE-GET") + " mm \n"
+ else:
+ log_msg = log_msg + "Collimator Mizar: " + str(caget("SLMUV01-LAPT100:IRIS-POS-GET")) + "\n"
+
log_msg = log_msg + "Charge B1: %0.2f" % caget("SINEG01-DICT215:B1_CHARGE-OP") + " pC at %0.2f" % phase0 + " deg beam phase\n"
log_msg = log_msg + "Charge B2: %0.2f" % caget("SINEG01-DICT215:B2_CHARGE-OP") + " pC at %0.2f" % phase0 + " deg beam phase\n"
log_msg = log_msg + "p-max: %0.2f" % p_max + " MeV/c at %0.2f" % ph_p_max + " deg beam phase\n"
diff --git a/script/RFscan/GunEnergyScanRfSet.py b/script/RFscan/GunEnergyScanRfSet.py
index 03fb403..11ed32b 100644
--- a/script/RFscan/GunEnergyScanRfSet.py
+++ b/script/RFscan/GunEnergyScanRfSet.py
@@ -2,7 +2,7 @@ dry_run = False
do_elog = True
if get_exec_pars().source == CommandSource.ui:
- bph_ref_user = 90.0
+ bph_ref_user = 89.0
plt = None
else:
bph_ref_user = args[0]
@@ -11,7 +11,6 @@ phase_offset_old = caget("SINEG01-RSYS:SET-VSUM-PHASE-OFFSET-BASE")
phase_offset_new = phase_offset_old - (bph_ref_user - 90.0)
if not dry_run:
caput("SINEG01-RSYS:SET-VSUM-PHASE-OFFSET-BASE" , phase_offset_new )
- caput("SINEG01-RSYS:CMD-LOAD-CALIB-BEAM" , 1 )
if do_elog:
title = "Set gun phase"
log_msg = "SINEG01-RSYS:SET-VSUM-PHASE-OFFSET-BASE: %8.2f" % phase_offset_new + " deg (was %8.2f" % phase_offset_old + " deg)\n"
diff --git a/script/RFscan/SchottkyScan.py b/script/RFscan/SchottkyScan.py
index c0531af..ffb4bbc 100644
--- a/script/RFscan/SchottkyScan.py
+++ b/script/RFscan/SchottkyScan.py
@@ -3,8 +3,6 @@ import ch.psi.pshell.epics.ChannelDouble as ChannelDouble
dry_run = False
do_elog = True
-#set_exec_pars(layout="default")
-
is_panel = get_exec_pars().source != CommandSource.ui #must be check before run
if is_panel:
@@ -19,7 +17,7 @@ else:
stop = 150.0
step = 5.0
nb = 1
- lat = 0.110
+ lat = 0.110 # lat is applied after each step (but not between samples)
plt = plot(None, title="Output")[0]
#Plot setup
@@ -46,9 +44,9 @@ else:
bph.config.minValue = -90.0
bph.config.maxValue = 360.0
-bph.config.precision = 4
-bph.config.resolution = 0.5
-bph.config.rotation = True
+bph.config.precision = 4 # nb of digit to display
+bph.config.resolution = 0.5 # set and get have to be within resolution
+bph.config.rotation = True # will go back to zero if > 360 deg
bph.config.save()
bph.initialize()
bph0 = bph.read() % 360.0
@@ -75,8 +73,7 @@ finally:
bph.close()
rph.close()
q.close()
- #st.close()
-#beamphase = r.getPositions(0)
+
beamphase = [(val + 90) % 360 - 90 for val in r.getPositions(0)]
rfphase = [(val.mean + 90) % 360 - 90 for val in r.getReadable(0)]
rfphaserms = [val.stdev for val in r.getReadable(0)]
@@ -109,17 +106,21 @@ if do_elog:
if get_option("Generated data file:\n" + get_exec_pars().path +"\n\n" + "Save to ELOG?", "YesNo") == "Yes":
Laser = str(caget("SLG-LGEN:WHICH_LASER"))
log_msg = "Data file: " + get_exec_pars().path + "\n\n"
- log_msg = log_msg + "Laser: " + Laser + "\n"
+ log_msg = log_msg + "Laser: " + Laser + "\n"
if Laser == "Alcor":
- log_msg = log_msg + "Energy plate: %0.2f" % caget("SLGTH01-LMRM-M074:MOT.RBV") + " deg \n"
+ log_msg = log_msg + "Energy plate: %0.2f" % caget("SLAUV01-LATN100:MOT.RBV") + " deg \n"
elif Laser == "Jaguar":
- log_msg = log_msg + "Energy plate: %0.2f" % caget("SLGJG-LMRM-M031:MOT.RBV") + " deg \n"
- if caget("SLGTV-LMTO-M053:MOT-ACT-POS") == "IRIS":
- log_msg = log_msg + "Collimator: IRIS %0.2f" % caget("SLGTV-LAPP:SIZE-GET") + " mm \n"
+ log_msg = log_msg + "Energy plate: %0.2f" % caget("SLJUV01-LATN100:MOT.RBV") + " deg \n"
+ if caget("SLAUV01-LAPT100:IRIS-POS-GET") == "IRIS":
+ log_msg = log_msg + "Collimator Alcor: IRIS %0.2f" % caget("SLAUV01-LAPT100:SIZE-GET") + " mm \n"
else:
- log_msg = log_msg + "Collimator: " + str(caget("SLGTV-LMTO-M053:MOT-ACT-POS")) + "\n"
- log_msg = log_msg + "Charge: %0.2f" % caget("SINEG01-DICT215:B1_CHARGE-OP") + " pC at %0.2f" % bph0 + " deg beam phase\n"
- log_msg = log_msg + "Charge onset: %0.2f" % x1 + " deg \n"
+ log_msg = log_msg + "Collimator Alcor: " + str(caget("SLAUV01-LAPT100:IRIS-POS-GET")) + "\n"
+ if caget("SLMUV01-LAPT100:IRIS-POS-GET") == "IRIS":
+ log_msg = log_msg + "Collimator Mizar: IRIS %0.2f" % caget("SLMUV01-LAPT100:SIZE-GET") + " mm \n"
+ else:
+ log_msg = log_msg + "Collimator Mizar: " + str(caget("SLMUV01-LAPT100:IRIS-POS-GET")) + "\n"
+ log_msg = log_msg + "Charge: %0.2f" % caget("SINEG01-DICT215:B1_CHARGE-OP") + " pC at %0.2f" % bph0 + " deg beam phase\n"
+ log_msg = log_msg + "Charge onset: %0.2f" % x1 + " deg \n"
attachments = []
if plt is not None:
sleep(0.1) #Give some time to plot to be finished - it is not sync with acquisition
diff --git a/script/RFscan/phase_scan_caqtdm.py b/script/RFscan/phase_scan_caqtdm.py
index 141768f..aae26f2 100644
--- a/script/RFscan/phase_scan_caqtdm.py
+++ b/script/RFscan/phase_scan_caqtdm.py
@@ -129,12 +129,15 @@ save_dataset ("scan 1/processed/On-crest VS-phase" , ph_crest )
save_dataset ("scan 1/processed/VS-phase offset" , phase_offset )
save_dataset ("scan 1/processed/Amplitude scale" , amplitude_scale )
save_dataset ("scan 1/processed/Power scale" , power_scale )
+save_dataset ("scan 1/processed/Dispersion" , disp )
+
set_attribute("scan 1/processed/Energy" , "Unit", "MeV" )
set_attribute("scan 1/processed/Energy gain" , "Unit", "MeV" )
set_attribute("scan 1/processed/On-crest VS-phase" , "Unit", "deg" )
set_attribute("scan 1/processed/VS-phase offset" , "Unit", "deg" )
set_attribute("scan 1/processed/Amplitude scale" , "Unit", "MV" )
set_attribute("scan 1/processed/Power scale" , "Unit", "MW/MV^2" )
+set_attribute("scan 1/processed/Dispersion" , "Unit", "mm" )
#Elog entry
if do_elog:
@@ -144,6 +147,7 @@ if do_elog:
log_msg = log_msg + "Energy gain: %0.3f" % fit_amplitude + " MeV \n"
log_msg = log_msg + "VS-phase offset: %0.2f" % phase_offset + " deg \n"
log_msg = log_msg + "Amplitude scale: %0.3f" % amplitude_scale + " MV \n"
- log_msg = log_msg + "Power scale: %0.7f" % power_scale + " MW/MV^2"
+ log_msg = log_msg + "Power scale: %0.7f" % power_scale + " MW/MV^2 \n"
+ log_msg = log_msg + "Dispersion: %0.4f" % disp + " mm"
attachments = get_plot_snapshots(size=(600,400))
elog(title, log_msg, attachments)
diff --git a/script/RFscan/phase_scan_caqtdm_set.py b/script/RFscan/phase_scan_caqtdm_set.py
index 4e61820..1372f21 100644
--- a/script/RFscan/phase_scan_caqtdm_set.py
+++ b/script/RFscan/phase_scan_caqtdm_set.py
@@ -31,6 +31,6 @@ if n > 0:
log_msg = ""
if (phase_set == 'True'): log_msg = log_msg + station + "-RSYS:SET-VSUM-PHASE-OFFSET-BASE: %12.2f" % phase_offset + " deg (was %12.2f" % phase_offset_old + " deg )\n"
if (ampli_set == 'True'): log_msg = log_msg + station + "-RSYS:SET-VSUM-AMPLT-SCALE: %12.3f" % amplitude_scale + " MV (was %12.3f" % amplitude_scale_old + " MV )\n"
- if (power_set == 'True'): log_msg = log_msg + station + "-RSYS:SET-VOLT-POWER-SCALE: %12.7f" % power_scale + " MW/MV^2 (was %12.5f" % power_scale_old + " MW/MV^2)"
+ if (power_set == 'True'): log_msg = log_msg + station + "-RSYS:SET-VOLT-POWER-SCALE: %12.7f" % power_scale + " MW/MV^2 (was %12.7f" % power_scale_old + " MW/MV^2)"
attachments = []
elog(title, log_msg, attachments)
diff --git a/script/Tools/RfEnergyCalib.py b/script/Tools/RfEnergyCalib.py
new file mode 100644
index 0000000..b610441
--- /dev/null
+++ b/script/Tools/RfEnergyCalib.py
@@ -0,0 +1,39 @@
+E1 = 3722.0 # old energy
+E2 = 3789.0 # new energy
+
+do_elog = True
+
+#stationlist = ("S10CB01","S10CB02","S10CB03","S10CB04","S10CB05","S10CB06","S10CB07","S10CB08","S10CB09")
+#stationlist = ("S20CB01","S20CB02","S20CB03","S20CB04")
+stationlist = ("S20CB01","S20CB02","S20CB03","S20CB04","S30CB01","S30CB02","S30CB03","S30CB04","S30CB05","S30CB06","S30CB07","S30CB08","S30CB09","S30CB10","S30CB11","S30CB12","S30CB13")
+
+A1, A2 = {}, {}
+P1, P2 = {}, {}
+for station in stationlist:
+ A = caget(station + "-RSYS:SET-VSUM-AMPLT-SCALE") # MV/unit
+ P = caget(station + "-RSYS:SET-VOLT-POWER-SCALE") # MW/MV^2
+ A1[station] = A
+ A2[station] = A * E2 / E1
+ P1[station] = P
+ P2[station] = P * (E1 / E2)**2
+# set RF on-delay
+caput("SIN-TIMAST-TMA:Beam-RF-Delay-Sel",1)
+caput("SIN-TIMAST-TMA:Beam-Apply-Cmd.PROC",1)
+for station in stationlist:
+ caput(station + "-RSYS:SET-VSUM-AMPLT-SCALE", A2[station])
+ caput(station + "-RSYS:SET-VOLT-POWER-SCALE", P2[station])
+ caput(station + "-RSYS:CMD-LOAD-CALIB-BEAM", 1)
+# set RF on-beam
+caput("SIN-TIMAST-TMA:Beam-RF-Delay-Sel",0)
+caput("SIN-TIMAST-TMA:Beam-Apply-Cmd.PROC",1)
+#Elog entry
+if do_elog:
+ title = "Energy calibration scaling"
+ log_msg = "Old energy: %0.2f" % E1 + " MeV/c\n"
+ log_msg = log_msg + "New energy: %0.2f" % E2 + " MeV/c\n\n"
+ log_msg = log_msg + " A1 A2 P1 P2 \n"
+ for station in stationlist:
+ log_msg = log_msg + station + "%10.2f%10.2f%10.6f%10.6f" % (A1[station],A2[station],P1[station],P2[station]) + " \n"
+ attachments = None
+ elog(title, log_msg)
+
\ No newline at end of file
diff --git a/script/Tools/RfEnergyCalib_inj.py b/script/Tools/RfEnergyCalib_inj.py
new file mode 100644
index 0000000..63f5bb1
--- /dev/null
+++ b/script/Tools/RfEnergyCalib_inj.py
@@ -0,0 +1,41 @@
+E1 = 288.91 # old energy
+E2 = 300.00 # new energy
+
+do_elog = True
+
+stationlist = ("SINSB03","SINSB04","SINXB01")
+#stationlist = ("SINSB01","SINSB02","SINSB03","SINSB04","SINXB01")
+#stationlist = ("S10CB01","S10CB02","S10CB03","S10CB04","S10CB05","S10CB06","S10CB07","S10CB08","S10CB09")
+#stationlist = ("S20CB01","S20CB02","S20CB03","S20CB04")
+#stationlist = ("S30CB01","S30CB02","S30CB03","S30CB04","S30CB05","S30CB06","S30CB07","S30CB08","S30CB09","S30CB10","S30CB11","S30CB12","S30CB13")
+
+A1, A2 = {}, {}
+P1, P2 = {}, {}
+for station in stationlist:
+ A = caget(station + "-RSYS:SET-VSUM-AMPLT-SCALE") # MV/unit
+ P = caget(station + "-RSYS:SET-VOLT-POWER-SCALE") # MW/MV^2
+ A1[station] = A
+ A2[station] = A * E2 / E1
+ P1[station] = P
+ P2[station] = P * (E1 / E2)**2
+# set RF on-delay
+caput("SIN-TIMAST-TMA:Beam-RF-Delay-Sel",1)
+caput("SIN-TIMAST-TMA:Beam-Apply-Cmd.PROC",1)
+for station in stationlist:
+ caput(station + "-RSYS:SET-VSUM-AMPLT-SCALE", A2[station])
+ caput(station + "-RSYS:SET-VOLT-POWER-SCALE", P2[station])
+ caput(station + "-RSYS:CMD-LOAD-CALIB-BEAM", 1)
+# set RF on-beam
+caput("SIN-TIMAST-TMA:Beam-RF-Delay-Sel",0)
+caput("SIN-TIMAST-TMA:Beam-Apply-Cmd.PROC",1)
+#Elog entry
+if do_elog:
+ title = "Energy calibration scaling"
+ log_msg = "Old energy: %0.2f" % E1 + " MeV/c\n"
+ log_msg = log_msg + "New energy: %0.2f" % E2 + " MeV/c\n\n"
+ log_msg = log_msg + " A1 A2 P1 P2 \n"
+ for station in stationlist:
+ log_msg = log_msg + station + "%10.2f%10.2f%10.6f%10.6f" % (A1[station],A2[station],P1[station],P2[station]) + " \n"
+ attachments = None
+ elog(title, log_msg)
+
\ No newline at end of file
diff --git a/script/Undulators/K-calc.py b/script/Undulators/K-calc.py
index d665456..629094c 100644
--- a/script/Undulators/K-calc.py
+++ b/script/Undulators/K-calc.py
@@ -1,5 +1,5 @@
-Eph1 = 9.45 # actual photon energy
-Eph2 = 12.0 # desired photon energy
+Eph1 = 11.312 # actual photon energy
+Eph2 = 12.00 # desired photon energy
do_elog = True
@@ -11,22 +11,15 @@ for und in undlist:
K1[und] = K
K2[und] = ((Eph1 / Eph2 * (K**2 + 2) - 2))**0.5
print K1,K2
-# set laser on-delay
-caput("SIN-TIMAST-TMA:Beam-Las-Delay-Sel",1)
-caput("SIN-TIMAST-TMA:Beam-Apply-Cmd.PROC",1)
#if Eph2 > Eph1 :
# for und in undlist: caput(und + "-UIND030:K_SET", 1.1)
# time.sleep(40.0)
for und in undlist: caput(und + "-UIND030:K_SET", K2[und])
-time.sleep(10.0)
-# set laser on-beam
-caput("SIN-TIMAST-TMA:Beam-Las-Delay-Sel",0)
-caput("SIN-TIMAST-TMA:Beam-Apply-Cmd.PROC",1)
#Elog entry
if do_elog:
title = "Wavelength change"
log_msg = "Old photon energy: %0.2f" % Eph1 + " kev\n"
log_msg = log_msg + "New photon energy: %0.2f" % Eph2 + " keV\n"
- attachments = none
+ attachments = None
elog(title, log_msg, attachments)
\ No newline at end of file
diff --git a/script/local.py b/script/local.py
index 03445f9..15c8a9c 100755
--- a/script/local.py
+++ b/script/local.py
@@ -25,20 +25,51 @@ LayoutSF.setExperimentArguments([charge, laser, rep_rate, destination_AR, energy
LASER_SETTLING_TIME = 3.0
-def laser_on():
- print "Laser On"
- caput("SIN-TIMAST-TMA:Beam-Las-Delay-Sel", 0)
+def laser_on(bunch=None):
+ print "Laser On - bunch “ + str(bunch)
+ #caput("SIN-TIMAST-TMA:Beam-Las-Delay-Sel", 0)
+ if (bunch==1) or (bunch is None):
+ caput("SWISSFEL-STATUS:Bunch-1-OnDelay-Sel", 0)
+ if (bunch==2) or (bunch is None):
+ caput("SWISSFEL-STATUS:Bunch-2-OnDelay-Sel", 0)
caput("SIN-TIMAST-TMA:Beam-Apply-Cmd.PROC", 1)
time.sleep(LASER_SETTLING_TIME)
-def laser_off():
- print "Laser Off"
- caput("SIN-TIMAST-TMA:Beam-Las-Delay-Sel", 1)
+def laser_off(bunch=None):
+ print "Laser Off - bunch “ + str(bunch)
+ #caput("SIN-TIMAST-TMA:Beam-Las-Delay-Sel", 1)
+ if (bunch==1) or (bunch is None):
+ caput("SWISSFEL-STATUS:Bunch-1-OnDelay-Sel", 1)
+ if (bunch==2) or (bunch is None):
+ caput("SWISSFEL-STATUS:Bunch-2-OnDelay-Sel", 1)
caput("SIN-TIMAST-TMA:Beam-Apply-Cmd.PROC", 1)
time.sleep(LASER_SETTLING_TIME)
-def is_laser_on():
- return (caget ("SIN-TIMAST-TMA:Beam-Las-Delay-Sel",'d') == 0 )
+def is_laser_on(bunch=None):
+ #return (caget ("SIN-TIMAST-TMA:Beam-Las-Delay-Sel",'d') == 0 )
+ if bunch==1:
+ return (caget ("SWISSFEL-STATUS:Bunch-1-OnDelay-Sel",'d') == 0 )
+ if bunch==2:
+ return (caget ("SWISSFEL-STATUS:Bunch-2-OnDelay-Sel",'d') == 0 )
+ if bunch is None:
+ return is_laser_on(1) and is_laser_on(2)
+
+def save_laser_state():
+ global laser_was_on_1, laser_was_on_2
+ laser_was_on_1 = is_laser_on(1)
+ laser_was_on_2 = is_laser_on(2)
+
+def restore_laser_state():
+ global laser_was_on_1, laser_was_on_2
+ if laser_was_on_1:
+ laser_on(1)
+ else:
+ laser_off(1)
+ if laser_was_on_2:
+ laser_on(2)
+ else:
+ laser_off(2)
+
# Switch off magnets
def ccr(magnet):
@@ -66,8 +97,15 @@ def switch_off_magnets(magnets = None):
def is_timing_ok():
return caget("SIN-TIMAST-TMA:SOS-COUNT-CHECK") == 0
-def get_repetition_rate():
- return caget("SIN-TIMAST-TMA:Evt-15-Freq-I")
+def get_repetition_rate(bunch=1, setp=False):
+ #return caget("SIN-TIMAST-TMA:Evt-15-Freq-I")
+ if setp:
+ sel = caget("SIN-TIMAST-TMA:Bunch-" + str(bunch) + "-Freq-Sel")
+ return float(sel.split(" ")[0])
+ if bunch==2:
+ return caget("SIN-TIMAST-TMA:Bunch-2-Appl-Freq-RB", 'd')
+ else:
+ return caget("SIN-TIMAST-TMA:Bunch-1-Appl-Freq-RB", 'd')
def ws_status():
"""
@@ -75,6 +113,13 @@ def ws_status():
"""
run("Diagnostics/WireScannersStatus")
+
+def get_beam_ok_channel(bunch):
+ if bunch==2:
+ return "SIN-CVME-TIFGUN-EVR0:BUNCH-2-OK"
+ if bunch==1:
+ return "SIN-CVME-TIFGUN-EVR0:BUNCH-1-OK"
+
###################################################################################################
# Maths utilities
###################################################################################################
@@ -336,11 +381,16 @@ def get_camera_type(camera_name):
# source = "server", "camtool", "bpm" or "direct"
def setup_camera_scan():
- global source, camera_name, bpm_name, number_images, use_background, multiple_background, number_backgrounds, dry_run, laser_was_on
- laser_was_on = is_laser_on()
+ global source, camera_name, bpm_name, number_images, use_background, multiple_background, number_backgrounds, dry_run
+ if not is_laser_on(1) and not is_laser_on(2):
+ raise Exception("Both bunches are on delay")
+ save_laser_state()
multiple_background = multiple_background and use_background
if source == "server":
- cam_server.start(camera_name)
+ if use_screen_panel_stream:
+ cam_server.start(camera_name + "_sp1", True)
+ else:
+ cam_server.start(camera_name)
if use_background:
if not dry_run:
laser_off()
@@ -379,7 +429,8 @@ def setup_camera_scan():
if not multiple_background:
if not dry_run:
- laser_on()
+ #laser_on()
+ restore_laser_state()
def before_sample_camera_scan():
global source, camera_name, number_images, use_background, multiple_background, number_backgrounds, dry_run
@@ -388,7 +439,8 @@ def before_sample_camera_scan():
bg = cam_server.captureBackground(number_backgrounds)
wait_cam_server_background(bg)
if not dry_run:
- laser_on()
+ #laser_on()
+ restore_laser_state()
wait_cam_server_message(number_images)
elif source == "camtool":
if multiple_background:
@@ -396,12 +448,14 @@ def before_sample_camera_scan():
camtool.grabBackground(camera_name, number_backgrounds)
camtool.start(camera_name, 0, use_background, None, 0.0, None)
if not dry_run:
- laser_on()
+ #laser_on()
+ restore_laser_state()
wait_camtool_message(number_images) #Wait filing the averager cache
else:
if multiple_background:
image_stats.grabBackground(number_backgrounds)
- laser_on()
+ #laser_on()
+ restore_laser_state()
image_stats.update()
def after_sample_camera_scan():
@@ -426,17 +480,14 @@ def get_camera_scan_sensors():
return sensors
def end_camera_scan():
- global source, camera_name, number_images, use_background, multiple_background, number_backgrounds, dry_run, laser_was_on
+ global source, camera_name, number_images, use_background, multiple_background, number_backgrounds, dry_run
#if source == "server": cam_server.stop()
#elif source == "camtool": camtool.stop()
#elif source == "camtool": camtool.stop()
#else: image_stats.stop()
if not dry_run:
- if laser_was_on:
- laser_on()
- else:
- laser_off()
- pass
+ restore_laser_state()
+
###################################################################################################
#CAS
###################################################################################################
diff --git a/script/test/CompressionBug.py b/script/test/CompressionBug.py
index 67dcf28..3bec014 100644
--- a/script/test/CompressionBug.py
+++ b/script/test/CompressionBug.py
@@ -13,7 +13,7 @@ BLMS = ["SINDI02-DBLM025", ] #"SINDI02-DBLM085", "S10DI01-DBLM045"]
sensors = []
st = Stream("pulse_id", dispatcher)
-#st.setFilter("SIN-CVME-TIFGUN-EVR0:BEAMOK == 1")
+#st.setFilter(get_beam_ok_channel(bunch=1) + " == 1")
for i in range(len(BLMS)):
blm = Scalar("blm" + str(i+1), st, BLMS[i] + ":B1_LOSS", 1, 0)
av = create_averager(blm, SAMPLES, interval = -1)
diff --git a/script/test/TestAlignmentScan.py b/script/test/TestAlignmentScan.py
index 40c1fbb..f4802d6 100644
--- a/script/test/TestAlignmentScan.py
+++ b/script/test/TestAlignmentScan.py
@@ -33,7 +33,6 @@ else:
centroid_excursion_plot = False
-#laser_was_on = is_laser_on()
positioner = DummyPositioner("positioner")
original_gun_solenoid = positioner.read()
@@ -60,11 +59,6 @@ finally:
end_camera_scan()
positioner.write(original_gun_solenoid)
-#if laser_was_on:
-# laser_on()
-#else:
-# laser_off()
-
# take the result of the scan and generate convex hull plot
if centroid_excursion_plot:
diff --git a/script/test/TestCPython.py b/script/test/TestCPython.py
new file mode 100644
index 0000000..aaac6bd
--- /dev/null
+++ b/script/test/TestCPython.py
@@ -0,0 +1,8 @@
+from jeputils import *
+
+data, dims = [1,2,3,4,5,6,7,8,9,0], [2,5]
+array = to_npa(data, dims,'d') #Auxiliary function to create numpy arrays from lists or java arrays.
+ret = call_jep("test/cpython", "calc", [array,])
+print ret.getDimensions(),ret.getData()
+
+ret = call_jep("test/cpython", "test_pandas")
\ No newline at end of file
diff --git a/script/test/TestDisp.py b/script/test/TestDisp.py
new file mode 100644
index 0000000..ecc6d30
--- /dev/null
+++ b/script/test/TestDisp.py
@@ -0,0 +1,16 @@
+channels = ["SIN-CVME-TIFGUN-EVR0:BUNCH-1-OK", "SIN-CVME-TIFGUN-EVR0:BUNCH-2-OK", \
+ "S10BC01-DBPM010:Q1","S10DI01-DICT025:B1_CHARGE", "SINEG01-DICT210:GUN_CHARGE"]
+
+
+st = Stream("st", dispatcher)
+for c in channels:
+ st.addScalar(c, c, 1, 0)
+
+
+try:
+ st.initialize()
+ st.start(True)
+ st.waitCacheChange(3000)
+ bscan(st, 100)
+except:
+ st.close()
\ No newline at end of file
diff --git a/script/test/TestPsen.py b/script/test/TestPsen.py
new file mode 100644
index 0000000..1345e20
--- /dev/null
+++ b/script/test/TestPsen.py
@@ -0,0 +1,38 @@
+from ch.psi.pshell.bs import Stream
+from ch.psi.pshell.bs import Provider
+from ch.psi.pshell.bs.ProviderConfig import SocketType;
+
+sources = [
+ #"tcp://sf-daqsync-06.psi.ch:9000", #AARES20-CAMS142-M4 Image Buffer
+ "tcp://sf-daqsync-06.psi.ch:9001", #AARES20-CAMS142-M4Data Buffer
+ #"tcp://sf-daqsync-06.psi.ch:9010", #SARES20-CAMS142-M5 Image Buffer
+ #"tcp://sf-daqsync-06.psi.ch:9011", #SARES20-CAMS142-M5 Data Buffer
+ #"tcp://sf-daqsync-05.psi.ch:9000", #SARES11-SPEC125-M1 Image Buffer
+ #"tcp://sf-daqsync-05.psi.ch:9001", #SARES11-SPEC125-M1 Data Buffer
+ #"tcp://sf-daqsync-05.psi.ch:9010", #SARES11-SPEC125-M2 Image Buffer
+ #"tcp://sf-daqsync-05.psi.ch:9011", #SARES11-SPEC125-M2 Data Buffer
+ ]
+
+class StreamListener (DeviceListener):
+ def onCacheChanged(self, device, value, former, timestamp, valueChange):
+ print value.pulseId
+l = StreamListener()
+
+for src in sources:
+ p = Provider("Provider",src, SocketType.PULL)
+ s = Stream("Stream", p)
+ try:
+ p.initialize()
+ s.initialize()
+ s.start(True)
+ #s.addListener(l)
+ s.waitCacheChange(3000)
+ v = s.getValues()
+ print "SUCCESS getting data from: ", src , " value=", v
+ #time.sleep(60.0)
+ except:
+ print "ERROR getting data from: ", src
+ finally:
+ s.close()
+ p.close()
+
diff --git a/script/test/TestSigProcess.py b/script/test/TestSigProcess.py
index 85534a5..d8e4420 100644
--- a/script/test/TestSigProcess.py
+++ b/script/test/TestSigProcess.py
@@ -1,8 +1,8 @@
run("Diagnostics/sig_process_wrapper")
-
+import random
#Loading test data
#p=get_plots("Wire Scan")[0]
-#s=p.getSeries(0)
+#s=p.getSeries(0)fra
#indexes = sorted(range(len(s.x)),key=lambda x:s.x[x])
#x,y = [s.x[x] for x in indexes], [s.y[x] for x in indexes]
x=[-200.30429237268825, -200.2650700434188, -200.22115208318002, -199.9457671375377, -199.86345548879072, -199.85213073174933, -199.35687977133284, -199.13811861090275, -197.97304970346386, -197.2952215624348, -195.09076092936948, -192.92276048970703, -191.96871876227698, -189.49577852322938, -187.9652790409825, -183.63756456925222, -180.04899765472996, -178.43839623242422, -174.07311671294445, -172.0410133577918, -165.90824309893102, -160.99771795989466, -159.30176653939253, -154.27688897558514, -152.0854103810786, -145.75652847587313, -140.80843828908465, -139.23982133191495, -134.27073891256106, -132.12649284133064, -125.95947209775511, -121.00309550337462, -119.26736932643232, -114.2706655484383, -112.07393889578914, -105.72295990367157, -100.8088439880125, -99.2034906238494, -94.30042325164636, -92.15010048151461, -85.92203653534293, -81.03913275494665, -79.27412793784428, -74.33487658582118, -72.06274362408762, -65.76562628131825, -60.91255356825276, -59.20334389560392, -54.33286972659312, -52.19387171350535, -45.94978737932291, -41.03014719193582, -39.301602568238906, -34.35572209014114, -32.04464301272608, -25.8221033382824, -20.922074315528747, -19.21590299233186, -14.31090212502093, -12.217203140101386, -5.9283722049240435, -0.9863587170369246, 0.7408048387279834, 5.71126832601389, 7.972628957879352, 14.204559894256546, 19.11839959633025, 20.8218087836657, 25.678748486941828, 27.822718344586864, 34.062659474970715, 38.9745656819391, 40.77409719734158, 45.72080631619803, 47.974156754056835, 54.23453768983539, 59.12020360609568, 60.77306570712026, 65.70734521458867, 67.8344660434617, 74.03187028154134, 78.96532114824849, 80.76070945985495, 85.74802197591286, 87.9140889204674, 94.18082276873524, 99.25790470037091, 100.68454787413205, 105.7213026221542, 107.79483801526698, 113.99555681638138, 119.0707052529143, 120.72715813056156, 125.77551384921307, 127.91257836719551, 134.2011330887875, 139.23043006997628, 140.71673537840158, 145.76288138835983, 147.80216629676042, 154.06420451405637, 159.0846626604798, 160.76183155710717, 165.73699067536242, 167.9265357747636, 173.96705069576544, 178.2522282751915, 179.9042617354548, 183.54586165856657, 185.23269803071796, 189.41678143751972, 191.87149157986588, 192.8741468985015, 195.0241934550453, 195.966634211846, 197.9821647518146, 198.99006812859284, 199.33202054855676, 199.91897441965887, 200.11536227958896, 200.22280936469997, 200.25181179127208]
diff --git a/script/test/TestWaveformListener.py b/script/test/TestWaveformListener.py
index 02b3cfe..0a13113 100644
--- a/script/test/TestWaveformListener.py
+++ b/script/test/TestWaveformListener.py
@@ -59,7 +59,7 @@ def after():
sensors = []
line_plots = []
st = Stream("pulse_id", dispatcher)
-st.setFilter("SIN-CVME-TIFGUN-EVR0:BEAMOK == 1")
+st.setFilter(get_beam_ok_channel(bunch=1) + " == 1")
for i in range(len(BLMS)):
blm = Scalar("blm" + str(i+1), st, BLMS[i] + ":B1_LOSS", 1, 0)
av = create_averager(blm, SAMPLES, interval = -1)
@@ -87,7 +87,6 @@ for i in range(len(BPMS)):
sensors.append(av1.samples)
line_plots.append(av1.samples)
-#Scalar("beam_ok" , st, "SIN-CVME-TIFGUN-EVR0:BEAMOK" , 1, 0)
try:
st.initialize()
st.start()
diff --git a/script/test/TestWireScanChannels.py b/script/test/TestWireScanChannels.py
index 7b317cc..6114186 100644
--- a/script/test/TestWireScanChannels.py
+++ b/script/test/TestWireScanChannels.py
@@ -2,14 +2,14 @@ blm = "S10DI01-DBLM045"
channels = ["S10DI01-DWSC010:CURR_CYCL","S10CB02-DBPM420:X1","S10DI01-DWSC010:SCANNING",blm+":WS_RUNNING", \
"S10CB02-DBPM420:Y1","S10DI01-DBLM015:B1_LOSS","S10CB02-DBPM420:Q1","S10BD01-DBPM020:Q1","S10DI01-DWSC010:ENC_1_BS", \
- "S10BD01-DBPM020:X1","S10BD01-DBPM020:Y1",blm+":B1_LOSS","SIN-CVME-TIFGUN-EVR0:BEAMOK"]
+ "S10BD01-DBPM020:X1","S10BD01-DBPM020:Y1",blm+":B1_LOSS",get_beam_ok_channel(bunch=1)]
blm = "SARCL02-DBLM135"
channels =[blm+":B1_LOSS", blm+":WS_RUNNING",
"SARCL01-DWSC160:CURR_CYCL","SARCL01-DWSC160:SCANNING","SARCL02-DBPM110:Q1","SARCL02-DBPM110:X1",
,"SARCL01-DBPM150:Y1","SARCL01-DBPM150:X1","SARCL01-DWSC160:ENC_1_BS","SARCL02-DBPM110:Y1",\
- "SARCL01-DBPM150:Q1","SIN-CVME-TIFGUN-EVR0:BEAMOK",
+ "SARCL01-DBPM150:Q1",get_beam_ok_channel(bunch=1),
#"SARCL02-DBLM355:B1_LOSS" ,
]
diff --git a/script/test/cpython.py b/script/test/cpython.py
new file mode 100644
index 0000000..a09513d
--- /dev/null
+++ b/script/test/cpython.py
@@ -0,0 +1,116 @@
+###################################################################################################
+# This moddule is called by demo scripts to execute and embed CPython.
+# Must be put in the scripts folder, or else in the python path.
+###################################################################################################
+
+import sys
+import os
+
+import matplotlib
+matplotlib.use('TkAgg')
+
+import pandas as pd
+import numpy as np
+import matplotlib.pyplot as plt
+
+try:
+ import tkinter as tk
+except:
+ import Tkinter as tk
+
+
+def calc(array):
+ return np.transpose(array + array)
+
+
+def test_pandas():
+ s = pd.Series([1,3,5,np.nan,6,8])
+ print (s)
+ dates = pd.date_range('20130101', periods=6)
+ print (dates)
+ df = pd.DataFrame(np.random.randn(6,4), index=dates, columns=list('ABCD'))
+ print (df)
+ df2 = pd.DataFrame({ 'A' : 1.,
+ 'B' : pd.Timestamp('20130102'),
+ 'C' : pd.Series(1,index=list(range(4)),dtype='float32'),
+ 'D' : np.array([3] * 4,dtype='int32'),
+ 'E' : pd.Categorical(["test","train","test","train"]),
+ 'F' : 'foo' })
+ print (df2)
+ print (df2.dtypes)
+ print (df.head())
+ print (df.tail(3))
+ print (df.values)
+ print (df.describe())
+ print (df.T)
+ print (df.sort_index(axis=1, ascending=False))
+ #print (df.sort_values(by='B'))
+ print (df['A'])
+ print (df[0:3])
+ print (df.mean())
+ return str(df.mean())
+
+
+def test_tkinter():
+ root = tk.Tk()
+ listb = tk.Listbox(root)
+ for item in ["Hello", "World"]:
+ listb.insert(0,item)
+ listb.pack()
+ root.mainloop()
+
+
+def test_matplotlib(start,stop,step):
+ import threading
+ x = np.arange(start,stop,step)
+ y = np.exp(-x)
+
+ # example variable error bar values
+ yerr = 0.1 + 0.2*np.sqrt(x)
+ xerr = 0.1 + yerr
+
+ # First illustrate basic pyplot interface, using defaults where possible.
+ plt.figure()
+ plt.errorbar(x, y, xerr=0.2, yerr=0.4)
+ plt.title("Simplest errorbars, 0.2 in x, 0.4 in y")
+
+ # Now switch to a more OO interface to exercise more features.
+ fig, axs = plt.subplots(nrows=2, ncols=2, sharex=True)
+ ax = axs[0,0]
+ ax.errorbar(x, y, yerr=yerr, fmt='o')
+ ax.set_title('Vert. symmetric')
+
+ # With 4 subplots, reduce the number of axis ticks to avoid crowding.
+ ax.locator_params(nbins=4)
+
+ ax = axs[0,1]
+ ax.errorbar(x, y, xerr=xerr, fmt='o')
+ ax.set_title('Hor. symmetric')
+
+ ax = axs[1,0]
+ ax.errorbar(x, y, yerr=[yerr, 2*yerr], xerr=[xerr, 2*xerr], fmt='--o')
+ ax.set_title('H, V asymmetric')
+
+ ax = axs[1,1]
+ ax.set_yscale('log')
+ # Here we have to be careful to keep all y values positive:
+ ylower = np.maximum(1e-2, y - yerr)
+ yerr_lower = y - ylower
+
+ ax.errorbar(x, y, yerr=[yerr_lower, 2*yerr], xerr=xerr,
+ fmt='o', ecolor='g', capthick=2)
+ ax.set_title('Mixed sym., log y')
+
+ fig.suptitle('Variable errorbars')
+
+ plt.show()
+ return [start,stop,step]
+
+
+if __name__ == "__main__":
+ x = np.arange(0, 5, 0.1)
+ y = np.sin(x)
+ plt.plot(x, y)
+ plt.show()
+
+
diff --git a/script/test/scale_ECOL_MCOR_MSEX.py b/script/test/scale_ECOL_MCOR_MSEX.py
new file mode 100644
index 0000000..2f1fe01
--- /dev/null
+++ b/script/test/scale_ECOL_MCOR_MSEX.py
@@ -0,0 +1,18 @@
+#devlist = ['SARCL02-MSEX255:I-SET', 'SARCL02-MSEX305:I-SET']
+devlist = ['SARCL02-MCRX100:I-SET', 'SARCL02-MCRX120:I-SET', 'SARCL02-MCRX200:I-SET', 'SARCL02-MCRX230:I-SET',
+ 'SARCL02-MCRX240:I-SET', 'SARCL02-MCRX400:I-SET', 'SARCL02-MCRX480:I-SET', 'SARCL02-MCRX500:I-SET',
+ 'SARCL02-MCRX320:I-SET', 'SARCL02-MCRX340:I-SET', 'SARCL02-MCRX450:I-SET' ]
+ #SARCL02-MCRY120:I-SET, SARCL02-MCRY230:I-SET, SARCL02-MCRY240:I-SET, SARCL02-MCRY480:I-SET,
+ #SARCL02-MCRY320:I-SET, SARCL02-MCRY340:I-SET, SARCL02-MCRY450:I-SET
+energy = 2840.0
+energynew = 3398.0
+efactor = energynew / energy
+print(efactor)
+
+for dev in devlist:
+ print('\n' + dev)
+ acq = caget(dev)
+ print(acq)
+ setval = acq * efactor
+ print(setval)
+ caput(dev, setval)
\ No newline at end of file