Window.Size property, new visible parameter for columns. Experimental stuff

This commit is contained in:
MikeTheWatchGuy 2018-12-03 19:16:49 -05:00
parent 76d34616a6
commit ce7ac6f930
1 changed files with 41 additions and 10 deletions

View File

@ -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: