summaryrefslogtreecommitdiff
path: root/df10ch_setup_pkg/layout_dlg.py
diff options
context:
space:
mode:
Diffstat (limited to 'df10ch_setup_pkg/layout_dlg.py')
-rw-r--r--df10ch_setup_pkg/layout_dlg.py87
1 files changed, 67 insertions, 20 deletions
diff --git a/df10ch_setup_pkg/layout_dlg.py b/df10ch_setup_pkg/layout_dlg.py
index 500c029..7fc9ed7 100644
--- a/df10ch_setup_pkg/layout_dlg.py
+++ b/df10ch_setup_pkg/layout_dlg.py
@@ -29,36 +29,37 @@ import device_drv
class LayoutDialog:
def __init__(self, areasDlg, master=None, **args):
self.areasDlg = areasDlg
+ self.edgeWeighting = 0
+ self.analyzeSize = 0
+ self.overscan = 0
self.numAreas = [ 0 ] * device_drv.NumBaseAreas()
- self.varNumAreas = list()
- for i in range(device_drv.NumBaseAreas()):
- self.varNumAreas.append(StringVar())
root = Frame(master, **args)
self.root = root
+ root.bind("<Map>", self.cbSheetSelected)
- Label(root, text="Configure RGB-Areas", font=tkFont.Font(weight="bold")).grid(row=0, column=0, columnspan=5, padx=5, pady=5)
- Label(root, text="Top").grid(row=1, column=2)
- Label(root, text="TopLeft").grid(row=1, column=0, sticky=E)
- Label(root, text="Left").grid(row=3, column=0, sticky=E)
- Label(root, text="BottomLeft").grid(row=5, column=0, sticky=E)
- Label(root, text="TopRight").grid(row=1, column=4, sticky=W)
- Label(root, text="Right").grid(row=3, column=4, sticky=W)
- Label(root, text="BottomRight").grid(row=5, column=4, sticky=W)
- Label(root, text="Bottom").grid(row=5, column=2)
+ Label(root, text="Configure RGB-Areas", font=tkFont.Font(weight="bold")).grid(row=0, column=0, columnspan=8, padx=5, pady=5)
+ self.varNumAreas = list()
+ for i in range(device_drv.NumBaseAreas()):
+ self.varNumAreas.append(StringVar())
+
+ Label(root, text="TopLeft").grid(row=1, column=0, sticky=E)
i = device_drv.AreaIndex("TopLeft")
self.sbTopLeft = Spinbox(root, textvariable=self.varNumAreas[i], from_=0, to=device_drv.MAX_AREAS[i], width=2)
self.sbTopLeft.grid(row=2, column=1, padx=5, pady=5)
+ Label(root, text="TopRight").grid(row=1, column=4, sticky=W)
i = device_drv.AreaIndex("TopRight")
self.sbTopRight = Spinbox(root, textvariable=self.varNumAreas[i], from_=0, to=device_drv.MAX_AREAS[i], width=2)
self.sbTopRight.grid(row=2, column=3, padx=5, pady=5)
+ Label(root, text="BottomLeft").grid(row=5, column=0, sticky=E)
i = device_drv.AreaIndex("BottomLeft")
self.sbBottomLeft = Spinbox(root, textvariable=self.varNumAreas[i], from_=0, to=device_drv.MAX_AREAS[i], width=2)
self.sbBottomLeft.grid(row=4, column=1, padx=5, pady=5)
+ Label(root, text="BottomRight").grid(row=5, column=4, sticky=W)
i = device_drv.AreaIndex("BottomRight")
self.sbBottomRight = Spinbox(root, textvariable=self.varNumAreas[i], from_=0, to=device_drv.MAX_AREAS[i], width=2)
self.sbBottomRight.grid(row=4, column=3, padx=5, pady=5)
@@ -67,45 +68,91 @@ class LayoutDialog:
self.sbCenter = Spinbox(root, textvariable=self.varNumAreas[i], from_=0, to=device_drv.MAX_AREAS[i], width=2)
self.sbCenter.grid(row=3, column=2, padx=20, pady=20)
+ Label(root, text="Top").grid(row=1, column=2)
i = device_drv.AreaIndex("Top")
self.sbTop = Spinbox(root, textvariable=self.varNumAreas[i], from_=0, to=device_drv.MAX_AREAS[i], increment=1, width=3)
self.sbTop.grid(row=2, column=2, padx=5, pady=5)
+ Label(root, text="Bottom").grid(row=5, column=2)
i = device_drv.AreaIndex("Bottom")
self.sbBottom = Spinbox(root, textvariable=self.varNumAreas[i], from_=0, to=device_drv.MAX_AREAS[i], increment=1, width=3)
self.sbBottom.grid(row=4, column=2, padx=5, pady=5)
+ Label(root, text="Left").grid(row=3, column=0, sticky=E)
i = device_drv.AreaIndex("Left")
self.sbLeft = Spinbox(root, textvariable=self.varNumAreas[i], from_=0, to=device_drv.MAX_AREAS[i], increment=1, width=3)
self.sbLeft.grid(row=3, column=1, padx=5, pady=5)
+ Label(root, text="Right").grid(row=3, column=4, sticky=W)
i = device_drv.AreaIndex("Right")
self.sbRight = Spinbox(root, textvariable=self.varNumAreas[i], from_=0, to=device_drv.MAX_AREAS[i], increment=1, width=3)
self.sbRight.grid(row=3, column=3, padx=5, pady=5)
+ Label(root, text="Overscan [%1000]:").grid(row=2, column=6, sticky=E)
+ self.varOverscan = StringVar()
+ self.sbOverscan = Spinbox(root, textvariable=self.varOverscan, from_=device_drv.MIN_OVERSCAN, to=device_drv.MAX_OVERSCAN, increment=1, width=4)
+ self.sbOverscan.grid(row=2, column=7, padx=5, pady=5, sticky=W)
+
+ Label(root, text="Analyze window size:").grid(row=3, column=6, sticky=E)
+ self.varAnalyzeSize = StringVar()
+ self.sbAnalyzeSize = Spinbox(root, textvariable=self.varAnalyzeSize, from_=device_drv.MIN_ANALYZE_SIZE, to=device_drv.MAX_ANALYZE_SIZE, increment=1, width=4)
+ self.sbAnalyzeSize.grid(row=3, column=7, padx=5, pady=5, sticky=W)
+
+ Label(root, text="Edge weighting:").grid(row=4, column=6, sticky=E)
+ self.varWeight = StringVar()
+ self.sbWeight = Spinbox(root, textvariable=self.varWeight, from_=device_drv.MIN_EDGE_WEIGHTING, to=device_drv.MAX_EDGE_WEIGHTING, increment=1, width=4)
+ self.sbWeight.grid(row=4, column=7, padx=5, pady=5, sticky=W)
+
+ self.btShowEdgeWeighting = Button(root, text="Show edge weighting", command=self.cbShowEdgeWeighting)
+ self.btShowEdgeWeighting.grid(row=6, column=0, columnspan=7, padx=20, pady=20, ipadx=5, sticky=E)
+
self.btApply = Button(root, text="Apply", command=self.cbApply)
- self.btApply.grid(row=6, column=4, padx=20, pady=20, ipadx=5)
+ self.btApply.grid(row=6, column=7, columnspan=1, padx=20, pady=20, ipadx=5, sticky=E)
+ def cbSheetSelected(self, event):
+ self.areasDlg.resetAreas()
+
+ def cbShowEdgeWeighting(self):
+ self.applyValues()
+ self.areasDlg.showEdgeWeighting(self.edgeWeighting, self.root.winfo_toplevel())
+
def cbApply(self):
+ self.applyValues()
+
+ def applyValues(self):
for i in range(device_drv.NumBaseAreas()):
self.numAreas[i] = int(self.varNumAreas[i].get())
- self.areasDlg.configAreas(self.numAreas)
-
+ self.overscan = int(self.varOverscan.get())
+ self.analyzeSize = int(self.varAnalyzeSize.get())
+ self.edgeWeighting = int(self.varWeight.get())
+ self.areasDlg.configAreas(self.numAreas, self.overscan, self.analyzeSize)
+
def setLayoutFromConfig(self):
- for i in range(device_drv.NumBaseAreas()):
- self.numAreas[i] = 0
+ self.analyzeSize = 0
+ self.edgeWeighting = 0
+ self.overscan = 0
+ self.numAreas = [ 0 ] * device_drv.NumBaseAreas()
for ctrlId in device_drv.ConfigMap.keys():
config = device_drv.ConfigMap[ctrlId]
+ self.overscan = config.overscan
+ self.analyzeSize = config.analyzeSize
+ self.edgeWeighting = config.edgeWeighting
for i in range(device_drv.NumBaseAreas()):
if config.numAreas[i] > self.numAreas[i]:
self.numAreas[i] = config.numAreas[i]
for i in range(device_drv.NumBaseAreas()):
self.varNumAreas[i].set(self.numAreas[i])
- self.areasDlg.configAreas(self.numAreas)
-
+ self.varOverscan.set(self.overscan)
+ self.varAnalyzeSize.set(self.analyzeSize)
+ self.varWeight.set(self.edgeWeighting)
+ self.areasDlg.configAreas(self.numAreas, self.overscan, self.analyzeSize)
+
def setConfigFromLayout(self):
for ctrlId in device_drv.ConfigMap.keys():
config = device_drv.ConfigMap[ctrlId]
+ config.overscan = self.overscan
+ config.analyzeSize = self.analyzeSize
+ config.edgeWeighting = self.edgeWeighting
for i in range(device_drv.NumBaseAreas()):
config.numAreas[i] = self.numAreas[i]
-
+