Window.Size property, new visible parameter for columns. Experimental stuff
This commit is contained in:
parent
76d34616a6
commit
ce7ac6f930
|
@ -17,7 +17,7 @@ if not FORCE_PYQT5:
|
||||||
from PySide2.QtWidgets import QSpacerItem, QFrame, QGroupBox, QTextBrowser, QPlainTextEdit, QButtonGroup, QFileDialog, QTableWidget, QTabWidget, QTabBar, QTreeWidget, QTreeWidgetItem, QLayout, QTreeWidgetItemIterator, QProgressBar
|
from PySide2.QtWidgets import QSpacerItem, QFrame, QGroupBox, QTextBrowser, QPlainTextEdit, QButtonGroup, QFileDialog, QTableWidget, QTabWidget, QTabBar, QTreeWidget, QTreeWidgetItem, QLayout, QTreeWidgetItemIterator, QProgressBar
|
||||||
from PySide2.QtWidgets import QTableWidgetItem, QGraphicsView, QGraphicsScene, QGraphicsItemGroup, QMenu, QMenuBar, QAction, QSystemTrayIcon
|
from PySide2.QtWidgets import QTableWidgetItem, QGraphicsView, QGraphicsScene, QGraphicsItemGroup, QMenu, QMenuBar, QAction, QSystemTrayIcon
|
||||||
from PySide2.QtGui import QPainter, QPixmap, QPen, QColor, QBrush, QPainterPath, QFont, QImage, QIcon
|
from PySide2.QtGui import QPainter, QPixmap, QPen, QColor, QBrush, QPainterPath, QFont, QImage, QIcon
|
||||||
from PySide2.QtCore import Qt,QProcess, QEvent
|
from PySide2.QtCore import Qt,QProcess, QEvent, QSize
|
||||||
import PySide2.QtGui as QtGui
|
import PySide2.QtGui as QtGui
|
||||||
import PySide2.QtCore as QtCore
|
import PySide2.QtCore as QtCore
|
||||||
import PySide2.QtWidgets as QtWidgets
|
import PySide2.QtWidgets as QtWidgets
|
||||||
|
@ -29,7 +29,7 @@ if not FORCE_PYQT5:
|
||||||
from PyQt5.QtWidgets import QSpacerItem, QFrame, QGroupBox, QTextBrowser, QPlainTextEdit, QButtonGroup, QFileDialog, QTableWidget, QTabWidget, QTabBar, QTreeWidget, QTreeWidgetItem, QLayout, QTreeWidgetItemIterator, QProgressBar
|
from PyQt5.QtWidgets import QSpacerItem, QFrame, QGroupBox, QTextBrowser, QPlainTextEdit, QButtonGroup, QFileDialog, QTableWidget, QTabWidget, QTabBar, QTreeWidget, QTreeWidgetItem, QLayout, QTreeWidgetItemIterator, QProgressBar
|
||||||
from PyQt5.QtWidgets import QTableWidgetItem, QGraphicsView, QGraphicsScene, QGraphicsItemGroup, QMenu, QMenuBar, QAction, QSystemTrayIcon
|
from PyQt5.QtWidgets import QTableWidgetItem, QGraphicsView, QGraphicsScene, QGraphicsItemGroup, QMenu, QMenuBar, QAction, QSystemTrayIcon
|
||||||
from PyQt5.QtGui import QPainter, QPixmap, QPen, QColor, QBrush, QPainterPath, QFont, QImage, QIcon
|
from PyQt5.QtGui import QPainter, QPixmap, QPen, QColor, QBrush, QPainterPath, QFont, QImage, QIcon
|
||||||
from PyQt5.QtCore import Qt,QProcess, QEvent
|
from PyQt5.QtCore import Qt,QProcess, QEvent, QSize
|
||||||
import PyQt5.QtGui as QtGui
|
import PyQt5.QtGui as QtGui
|
||||||
import PyQt5.QtCore as QtCore
|
import PyQt5.QtCore as QtCore
|
||||||
import PyQt5.QtWidgets as QtWidgets
|
import PyQt5.QtWidgets as QtWidgets
|
||||||
|
@ -624,7 +624,7 @@ class Combo(Element):
|
||||||
self.QT_ComboBox.addItems(self.Values)
|
self.QT_ComboBox.addItems(self.Values)
|
||||||
|
|
||||||
|
|
||||||
def Update(self, value=None, values=None, set_to_index=None, disabled=None, readonly=None, background_color=None, text_color=None, font=None):
|
def Update(self, value=None, values=None, set_to_index=None, disabled=None, readonly=None, background_color=None, text_color=None, font=None, visible=None):
|
||||||
if values is not None:
|
if values is not None:
|
||||||
self.Values = values
|
self.Values = values
|
||||||
for i in range(self.QT_ComboBox.count()):
|
for i in range(self.QT_ComboBox.count()):
|
||||||
|
@ -643,6 +643,11 @@ class Combo(Element):
|
||||||
self.QT_ComboBox.setDisabled(False)
|
self.QT_ComboBox.setDisabled(False)
|
||||||
if readonly is not None:
|
if readonly is not None:
|
||||||
self.Readonly = readonly
|
self.Readonly = readonly
|
||||||
|
if visible is False:
|
||||||
|
self.QT_ComboBox.setVisible(False)
|
||||||
|
elif visible is True:
|
||||||
|
self.QT_ComboBox.setVisible(True)
|
||||||
|
|
||||||
super().Update(self.QT_ComboBox, background_color=background_color, text_color=text_color, font=font)
|
super().Update(self.QT_ComboBox, background_color=background_color, text_color=text_color, font=font)
|
||||||
|
|
||||||
|
|
||||||
|
@ -1455,7 +1460,7 @@ class Button(Element):
|
||||||
else:
|
else:
|
||||||
self.QT_QPushButton.setDisabled(False)
|
self.QT_QPushButton.setDisabled(False)
|
||||||
# fg, bg = self.ButtonColor
|
# fg, bg = self.ButtonColor
|
||||||
print(f'Button update fg, bg {fg}, {bg}')
|
# print(f'Button update fg, bg {fg}, {bg}')
|
||||||
super().Update(self.QT_QPushButton, background_color=bg, text_color=fg, font=font)
|
super().Update(self.QT_QPushButton, background_color=bg, text_color=fg, font=font)
|
||||||
|
|
||||||
|
|
||||||
|
@ -2185,7 +2190,7 @@ class Slider(Element):
|
||||||
return
|
return
|
||||||
element_callback_quit_mainloop(self)
|
element_callback_quit_mainloop(self)
|
||||||
|
|
||||||
def Update(self, value=None, range=(None, None), disabled=None):
|
def Update(self, value=None, range=(None, None), disabled=None, visible=None):
|
||||||
if value is not None:
|
if value is not None:
|
||||||
self.QT_Slider.setValue(int(value))
|
self.QT_Slider.setValue(int(value))
|
||||||
self.DefaultValue = value
|
self.DefaultValue = value
|
||||||
|
@ -2194,6 +2199,11 @@ class Slider(Element):
|
||||||
elif disabled == False:
|
elif disabled == False:
|
||||||
self.QT_Slider.setDisabled(False)
|
self.QT_Slider.setDisabled(False)
|
||||||
|
|
||||||
|
if visible is False:
|
||||||
|
self.QT_Slider.setVisible(False)
|
||||||
|
elif visible is True:
|
||||||
|
self.QT_Slider.setVisible(True)
|
||||||
|
|
||||||
def SliderChangedHandler(self, event):
|
def SliderChangedHandler(self, event):
|
||||||
# first, get the results table built
|
# first, get the results table built
|
||||||
# modify the Results table in the parent FlexForm object
|
# modify the Results table in the parent FlexForm object
|
||||||
|
@ -2302,7 +2312,7 @@ class Stretch(Element):
|
||||||
# Column #
|
# Column #
|
||||||
# ---------------------------------------------------------------------- #
|
# ---------------------------------------------------------------------- #
|
||||||
class Column(Element):
|
class Column(Element):
|
||||||
def __init__(self, layout, background_color=None, size=(None, None), pad=None, scrollable=False, key=None):
|
def __init__(self, layout, background_color=None, size=(None, None), pad=None, scrollable=False,visible=True, key=None):
|
||||||
'''
|
'''
|
||||||
Column Element
|
Column Element
|
||||||
:param layout:
|
:param layout:
|
||||||
|
@ -2326,10 +2336,12 @@ class Column(Element):
|
||||||
# self.ImageSize = image_size
|
# self.ImageSize = image_size
|
||||||
# self.ImageSubsample = image_subsample
|
# self.ImageSubsample = image_subsample
|
||||||
bg = background_color if background_color is not None else DEFAULT_BACKGROUND_COLOR
|
bg = background_color if background_color is not None else DEFAULT_BACKGROUND_COLOR
|
||||||
|
self.QT_QGroupBox = None
|
||||||
|
self.Visible = visible
|
||||||
|
|
||||||
self.Layout(layout)
|
self.Layout(layout)
|
||||||
|
|
||||||
super().__init__(ELEM_TYPE_COLUMN, background_color=background_color, size=size, pad=pad, key=key)
|
super().__init__(ELEM_TYPE_COLUMN, background_color=bg, size=size, pad=pad, key=key)
|
||||||
return
|
return
|
||||||
|
|
||||||
def AddRow(self, *args):
|
def AddRow(self, *args):
|
||||||
|
@ -2357,6 +2369,14 @@ class Column(Element):
|
||||||
element = row[col_num]
|
element = row[col_num]
|
||||||
return element
|
return element
|
||||||
|
|
||||||
|
|
||||||
|
def Update(self, visible=None):
|
||||||
|
if visible is False:
|
||||||
|
self.QT_QGroupBox.setVisible(False)
|
||||||
|
elif visible is True:
|
||||||
|
self.QT_QGroupBox.setVisible(True)
|
||||||
|
|
||||||
|
|
||||||
def __del__(self):
|
def __del__(self):
|
||||||
for row in self.Rows:
|
for row in self.Rows:
|
||||||
for element in row:
|
for element in row:
|
||||||
|
@ -3009,7 +3029,7 @@ class Window:
|
||||||
self.DisableClose = disable_close
|
self.DisableClose = disable_close
|
||||||
self._Hidden = False
|
self._Hidden = False
|
||||||
self.QTApplication = None
|
self.QTApplication = None
|
||||||
self.Size=size
|
self._Size=size
|
||||||
self.ElementPadding = element_padding or DEFAULT_ELEMENT_PADDING
|
self.ElementPadding = element_padding or DEFAULT_ELEMENT_PADDING
|
||||||
self.FocusElement = None
|
self.FocusElement = None
|
||||||
self.BackgroundImage = background_image
|
self.BackgroundImage = background_image
|
||||||
|
@ -3511,6 +3531,14 @@ class Window:
|
||||||
# print("quitting window")
|
# print("quitting window")
|
||||||
# self.QTApplication.exit() # kick the users out of the mainloop
|
# self.QTApplication.exit() # kick the users out of the mainloop
|
||||||
|
|
||||||
|
@property
|
||||||
|
def Size(self):
|
||||||
|
size = self.QT_QMainWindow.sizeHint()
|
||||||
|
return size.width(), size.height()
|
||||||
|
|
||||||
|
@Size.setter
|
||||||
|
def Size(self, size):
|
||||||
|
self.QT_QMainWindow.resize(QSize(size[0], size[1]))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -4327,6 +4355,7 @@ def PackFormIntoFrame(window, containing_frame, toplevel_win):
|
||||||
if element_type == ELEM_TYPE_COLUMN:
|
if element_type == ELEM_TYPE_COLUMN:
|
||||||
# column_widget = QWidget()
|
# column_widget = QWidget()
|
||||||
column_widget = QGroupBox()
|
column_widget = QGroupBox()
|
||||||
|
element.QT_QGroupBox = column_widget
|
||||||
# column_widget.setFrameShape(QtWidgets.QFrame.NoFrame)
|
# column_widget.setFrameShape(QtWidgets.QFrame.NoFrame)
|
||||||
|
|
||||||
style = create_style_from_font(font)
|
style = create_style_from_font(font)
|
||||||
|
@ -4344,6 +4373,8 @@ def PackFormIntoFrame(window, containing_frame, toplevel_win):
|
||||||
column_widget.setLayout(column_vbox)
|
column_widget.setLayout(column_vbox)
|
||||||
|
|
||||||
column_widget.setStyleSheet(style)
|
column_widget.setStyleSheet(style)
|
||||||
|
if not element.Visible:
|
||||||
|
column_widget.setVisible(False)
|
||||||
|
|
||||||
qt_row_layout.addWidget(column_widget)
|
qt_row_layout.addWidget(column_widget)
|
||||||
# ------------------------- TEXT element ------------------------- #
|
# ------------------------- TEXT element ------------------------- #
|
||||||
|
@ -5287,8 +5318,8 @@ def StartupTK(window):
|
||||||
# Resize the window to the size it should be at... dunno why I need to do this but I do...
|
# Resize the window to the size it should be at... dunno why I need to do this but I do...
|
||||||
window.QT_QMainWindow.resize(window.QT_QMainWindow.sizeHint())
|
window.QT_QMainWindow.resize(window.QT_QMainWindow.sizeHint())
|
||||||
|
|
||||||
if window.Size != (None, None):
|
if window._Size != (None, None):
|
||||||
window.QT_QMainWindow.resize(window.Size[0], window.Size[1])
|
window.QT_QMainWindow.resize(window._Size[0], window._Size[1])
|
||||||
|
|
||||||
timer = None
|
timer = None
|
||||||
if window.AutoClose:
|
if window.AutoClose:
|
||||||
|
|
Loading…
Reference in New Issue