From 4769d0601e8680f32392bbab006a90ead1b3f89d Mon Sep 17 00:00:00 2001 From: gambas Date: Sat, 15 Sep 2018 22:36:38 +0200 Subject: [PATCH] SidePanel: Animate opening and closing when Application.Animations is set. [GB.FORM] * BUG: SidePanel: It should work correctly in all cases now. * NEW: SidePanel: Animate opening and closing when Application.Animations is set. --- comp/src/gb.form/.project | 2 +- .../gb.form/.src/SidePanel/FSidePanel.class | 326 +++++++++++++----- .../gb.form/.src/SidePanel/FSidePanel.form | 2 +- .../gb.form/.src/SidePanel/SidePanel.class | 9 + .../gb.form/.src/Test/FTestArrangement.class | 14 + .../gb.form/.src/Test/FTestArrangement.form | 18 + .../gb.form/.src/Test/FTestSidePanel.class | 18 + .../src/gb.form/.src/Test/FTestSidePanel.form | 26 +- 8 files changed, 314 insertions(+), 101 deletions(-) create mode 100644 comp/src/gb.form/.src/Test/FTestArrangement.class create mode 100644 comp/src/gb.form/.src/Test/FTestArrangement.form diff --git a/comp/src/gb.form/.project b/comp/src/gb.form/.project index 41dde641e..24bfcb476 100644 --- a/comp/src/gb.form/.project +++ b/comp/src/gb.form/.project @@ -7,7 +7,7 @@ Component=gb.image Component=gb.gui Component=gb.settings Authors="BenoƮt Minisini" -Environment="GB_GUI=gb.qt5" +Environment="GB_GUI=gb.gtk" TabSize=2 Translate=1 Language=en diff --git a/comp/src/gb.form/.src/SidePanel/FSidePanel.class b/comp/src/gb.form/.src/SidePanel/FSidePanel.class index 95cfd9ad4..7047abd7b 100644 --- a/comp/src/gb.form/.src/SidePanel/FSidePanel.class +++ b/comp/src/gb.form/.src/SidePanel/FSidePanel.class @@ -23,14 +23,17 @@ Private $bDblClick As Boolean Private $bTransparent As Boolean Private $iMinSize As Integer -Private BUTTON_H As Integer = 6 -Private BUTTON_H_TRANS As Integer = 4 -Private BUTTON_W As Integer = 24 +Private BUTTON_H As Integer +Private TRANS_H As Integer +Private BUTTON_W As Integer Private $hShowPanel As Panel Private $hShowButtonLeft As DrawingArea Private $hShowButtonRight As DrawingArea +Private $hTimerAnim As Timer +Private $iTarget As Integer + ' Static Public Sub _init() ' ' $hHandleH = Picture["img/handle-h.png"] @@ -44,8 +47,10 @@ Public Sub _new() $bVisible = True $iOrientation = Align.Top $iMinSize = Desktop.Scale * 8 - 'btnSide.Transparent = True - 'btnSide2.Transparent = True + + BUTTON_H = Desktop.Scale * 0.75 + BUTTON_W = BUTTON_H * 4 + TRANS_H = Max(2, BUTTON_H * 0.5) End @@ -114,7 +119,7 @@ Private Sub RefreshPanel() D = Me.ClientH End Select - + 'D = Max(0, D - 8) If D < (BUTTON_W * 2 + 16) Then @@ -144,7 +149,7 @@ Private Sub RefreshPanel() panMove.Move(0, Y, Me.ClientW, BUTTON_H) - If $bVisible Then + If $bVisible Or If Not $bTransparent Then If W2 Then btnSide.Move(0, 0, W, BUTTON_H) btnSide2.Move(Me.ClientW - W2, 0, W2, BUTTON_H) @@ -168,7 +173,7 @@ Private Sub RefreshPanel() panMove.Move(Y, 0, BUTTON_H, Me.ClientH) - If $bVisible Then + If $bVisible Or If Not $bTransparent Then If W2 Then btnSide.Move(0, 0, BUTTON_H, W) btnSide2.Move(0, Me.ClientH - W2, BUTTON_H, W2) @@ -193,11 +198,7 @@ Private Sub RefreshPanel() 'If $bTransparent Then panSide.Move(0, 0, Me.ClientW, Me.ClientH) If $bTransparent Then - 'If $bSeparator Then - ' D = 1 - 'Else - D = 0 - 'Endif + D = 0 Else D = BUTTON_H Endif @@ -294,11 +295,11 @@ Private Sub RefreshArrow() End -Private Sub CreateShowButton() As DrawingArea +Private Sub CreateShowButton(hParent As Container) As DrawingArea Dim hCtrl As DrawingArea - hCtrl = New DrawingArea($hShowPanel) As "ShowButton" + hCtrl = New DrawingArea(hParent) As "ShowButton" hCtrl.Ignore = True 'hCtrl.Painted = True hCtrl.Resize(Desktop.Scale, Desktop.Scale) @@ -311,38 +312,59 @@ End Private Sub MoveShowButton() Dim D As Integer + Dim PH As Integer + Dim X, Y, W, H As Integer If $bVisible Then Return + If Not $bTransparent Then Return If Not $hShowPanel Then Return - D = If($bTransparent, BUTTON_H_TRANS, 0) - + D = If($bTransparent, TRANS_H, 0) + PH = If($bTransparent, TRANS_H, BUTTON_H) + + With Me.Parent + X = .X + Y = .Y + W = .W + H = .H + End With + + ' If Not $bVisible And If $bTransparent Then + ' If Me.Parent.Parent. + ' Select Case $iOrientation + ' Case Align.Top + ' Y = 0 + ' Case Align.Bottom + ' + ' End Select + ' Endif + With Me.Parent Select Case $iOrientation Case Align.Top - $hShowPanel.Move(.X, .Y, .W, BUTTON_H) + $hShowPanel.Move(.X, .Y, .W, PH) If $hShowButtonLeft Then - $hShowButtonLeft.Move(0, 0, BUTTON_W, BUTTON_H) - $hShowButtonRight.Move(.W - BUTTON_W, 0, BUTTON_W, BUTTON_H) + $hShowButtonLeft.Move($hShowPanel.X, $hShowPanel.Y, BUTTON_W, BUTTON_H) + $hShowButtonRight.Move($hShowPanel.X + .W - BUTTON_W, $hShowPanel.Y, BUTTON_W, BUTTON_H) Endif Case Align.Bottom - $hShowPanel.Move(.X, .Y - D, .W, BUTTON_H) + $hShowPanel.Move(.X, .Y - D, .W, PH) If $hShowButtonLeft Then - $hShowButtonLeft.Move(0, 0, BUTTON_W, BUTTON_H) - $hShowButtonRight.Move(.W - BUTTON_W, 0, BUTTON_W, BUTTON_H) + $hShowButtonLeft.Move($hShowPanel.X, .Y - BUTTON_H, BUTTON_W, BUTTON_H) + $hShowButtonRight.Move($hShowPanel.X + .W - BUTTON_W, .Y - BUTTON_H, BUTTON_W, BUTTON_H) Endif Case Align.Left - $hShowPanel.Move(.X, .Y, BUTTON_H, .H) + $hShowPanel.Move(.X, .Y, PH, .H) If $hShowButtonLeft Then - $hShowButtonLeft.Move(0, 0, BUTTON_H, BUTTON_W) - $hShowButtonRight.Move(0, .H - BUTTON_W, BUTTON_H, BUTTON_W) + $hShowButtonLeft.Move($hShowPanel.X, $hShowPanel.Y, BUTTON_H, BUTTON_W) + $hShowButtonRight.Move($hShowPanel.X, $hShowPanel.Y + .H - BUTTON_W, BUTTON_H, BUTTON_W) Endif Case Align.Right - $hShowPanel.Move(.X - D, .Y, BUTTON_H, .H) + $hShowPanel.Move(.X - D, .Y, PH, .H) If $hShowButtonLeft Then - $hShowButtonLeft.Move(0, 0, BUTTON_H, BUTTON_W) - $hShowButtonRight.Move(0, .H - BUTTON_W, BUTTON_H, BUTTON_W) + $hShowButtonLeft.Move(.X - BUTTON_H, $hShowPanel.Y, BUTTON_H, BUTTON_W) + $hShowButtonRight.Move(.X - BUTTON_H, $hShowPanel.Y + .H - BUTTON_W, BUTTON_H, BUTTON_W) Endif End Select @@ -352,36 +374,94 @@ Private Sub MoveShowButton() $hShowPanel.Show $hShowPanel.Raise + If $hShowButtonLeft Then + $hShowButtonLeft.Show + $hShowButtonLeft.Raise + $hShowButtonRight.Show + $hShowButtonRight.Raise + Endif End -Private Sub RefreshAll() +Private Sub UpdatePanelSize(D As Integer, Optional bAnimate As Boolean) As Boolean + + Dim DD As Integer + + Select Case $iOrientation + + Case Align.Top, Align.Bottom + + If Me.Parent.H = D Then Return True + + Case Align.Left, Align.Right + + If Me.Parent.W = D Then Return True + + End Select + + 'bParentIgnore = Me.Parent.Ignore + 'Me.Parent.Ignore = True + + Select Case $iOrientation + + Case Align.Top, Align.Bottom + + If bAnimate Then + DD = (D - Me.Parent.H + Sgn(D - Me.Parent.H)) \ 2 + Else + DD = D - Me.Parent.H + Endif + + Me.Parent.H += DD + If $iOrientation = Align.Bottom Then Me.Parent.Y -= DD + + Case Align.Left, Align.Right + + If bAnimate Then + DD = (D - Me.Parent.W + Sgn(D - Me.Parent.W)) \ 2 + Else + DD = D - Me.Parent.W + Endif + + Me.Parent.W += DD + If $iOrientation = Align.Right Then Me.Parent.X -= DD + + End Select + + 'Me.Parent.Ignore = bParentIgnore + +End + + +Public Sub RefreshAll() - Dim D As Integer Dim hParent As Container Dim hTabStrip As TabStrip Dim iIndex As Integer + Dim D As Integer + + btnSide.Visible = Not $bTransparent Or $bVisible + btnSide2.Visible = btnSide.Visible If Not $bOpened Then Return + 'Debug Me.Parent.Name;; Me.X;; Me.Y;; Me.W;; panMove.W;; Me.Parent.ClientH If $bVisible Then - panSide.Show 'Enabled = TRUE + 'panSide.Show 'Enabled = TRUE If $hShowPanel Then $hShowPanel.Hide + If $hShowButtonLeft Then + $hShowButtonLeft.Hide + $hShowButtonRight.Hide + Endif Else 'DEBUG ME.Parent.W;; ME.CLientW - panSide.Hide 'Enabled = FALSE + 'panSide.Hide 'Enabled = FALSE - If $bTransparent Then - D = 0 'If($bSeparator, 1, 0) - Else - D = BUTTON_H - Endif - - If Not $hShowPanel Then + If Not $hShowPanel And If $bTransparent Then hParent = Me.Parent.Parent @@ -391,35 +471,26 @@ Private Sub RefreshAll() hTabStrip.Index = hTabStrip.FindIndex(Me.Parent) Endif + $hShowButtonLeft = CreateShowButton(hParent) + $hShowButtonRight = CreateShowButton(hParent) + $hShowPanel = New Panel(hParent) As "panMove" + $hShowPanel.Ignore = True + $hShowPanel.Mouse = Mouse.Pointing If hTabStrip Then hTabStrip.Index = iIndex - $hShowPanel.Ignore = True - $hShowPanel.Mouse = Mouse.Pointing - $hShowButtonLeft = CreateShowButton() - $hShowButtonRight = CreateShowButton() - Endif - Select Case $iOrientation - Case Align.Top - Me.Parent.H = D - Case Align.Bottom - Me.Parent.Y += Me.Parent.H - D - Me.Parent.H = D - Case Align.Left - Me.Parent.W = D - Case Align.Right - Me.Parent.X += Me.Parent.W - D - Me.Parent.W = D - End Select - + If Not $hTimerAnim Then + D = If($bTransparent, 0, BUTTON_H) + UpdatePanelSize(D) + Endif MoveShowButton Endif - UpdateBackground + 'UpdateBackground RefreshArrow RefreshPanel RefreshButtons @@ -429,16 +500,43 @@ Private Sub RefreshAll() End +Private Sub AfterTogglePanel() + + Dim W, H As Integer + + If Not $bVisible Then + + RefreshAll + + Else + + If $W And If $H Then + W = $W + H = $H + If IsVertical() Then + W = Me.Parent.W + Else + H = Me.Parent.H + Endif + Me.Parent.Move($X, $Y, W, H) + $W = 0 + $H = 0 + Endif + + RefreshAll + + Endif + +End + Private Sub TogglePanel() If Me.Parent.Design Then Return + If $hTimerAnim Then Return If $bVisible Then - btnSide.Hide - btnSide2.Hide - With Me.Parent $X = .X $Y = .Y @@ -446,28 +544,52 @@ Private Sub TogglePanel() $H = .Height End With + 'Debug $X;; $Y;; $W;; $H + $bVisible = False - RefreshAll - - Action.Raise(Me.Parent) - - GetParent()._Hide - - Else - - btnSide.Show - btnSide2.Show - - $bVisible = True - - If $W And If $H Then - Me.Parent.Move($X, $Y, $W, $H) - $W = 0 - $H = 0 + If Application.Animations Then + + $iTarget = If($bTransparent, 0, BUTTON_H) + + $hTimerAnim = New Timer As "TimerAnim" + $hTimerAnim.Delay = 20 + $hTimerAnim.Start + + Else + + AfterTogglePanel + Endif - RefreshAll + Action.Raise(Me.Parent) + + GetParent()._Hide + + Else + + $bVisible = True + + If Application.Animations Then + + panSide.Show + sepSide.Visible = $bSeparator + + If $iOrientation = Align.Top Or If $iOrientation = Align.Bottom Then + $iTarget = $H + Else + $iTarget = $W + Endif + + $hTimerAnim = New Timer As "TimerAnim" + $hTimerAnim.Delay = 20 + $hTimerAnim.Start + + Else + + AfterTogglePanel + + Endif Action.Raise(Me.Parent) @@ -477,6 +599,17 @@ Private Sub TogglePanel() End +Public Sub TimerAnim_Timer() + + If UpdatePanelSize($iTarget, True) Then + $hTimerAnim.Stop + $hTimerAnim = Null + AfterTogglePanel + Endif + +End + + Public Sub btnSide_MouseUp() If Me.Parent.Design Then Return @@ -736,9 +869,14 @@ End Public Sub btnSide_Draw() + Dim iOrientation As Integer + If Me.Parent.Design Or If Not $bTransparent Or If $bInside Then - DrawArrow(Last, $iOrientation) + iOrientation = $iOrientation + If Not $bVisible Then iOrientation = InvertOrientation(iOrientation) + + DrawArrow(Last, iOrientation) ' If $hArrow Then ' Draw.Image($hArrow, (Last.W - $hArrow.W) / 2, (Last.H - $hArrow.H) / 2) @@ -786,15 +924,15 @@ Public Sub SetSeparator(bVisible As Boolean) End -Private Sub UpdateBackground() - - ' If $bInside And If Not $bVisible Then - ' panMove.Background = Color.SelectedBackground - ' Else - ' panMove.Background = Color.Default - 'Endif - -End +' Private Sub UpdateBackground() +' +' ' If $bInside And If Not $bVisible Then +' ' panMove.Background = Color.SelectedBackground +' ' Else +' ' panMove.Background = Color.Default +' 'Endif +' +' End Private Sub RefreshButtons() @@ -815,7 +953,7 @@ Public Sub panMove_Enter() 'Debug $bInside = True - UpdateBackground + 'UpdateBackground RefreshButtons End @@ -824,7 +962,7 @@ Public Sub panMove_Leave() 'Debug $bInside = False - UpdateBackground + 'UpdateBackground RefreshButtons End @@ -858,12 +996,14 @@ End Public Sub ShowButton_Enter() Last.Refresh + panMove_Enter End Public Sub ShowButton_Leave() Last.Refresh + panMove_Leave End @@ -952,6 +1092,7 @@ End Public Sub SetTransparent(bTransparent As Boolean) + If $bTransparent = bTransparent Then Return $bTransparent = bTransparent RefreshAll @@ -1006,4 +1147,3 @@ Public Sub SetMinSize(iMinSize As Integer) $iMinSize = Max(Desktop.Scale, iMinSize) End - diff --git a/comp/src/gb.form/.src/SidePanel/FSidePanel.form b/comp/src/gb.form/.src/SidePanel/FSidePanel.form index 264a3c754..9faae3008 100644 --- a/comp/src/gb.form/.src/SidePanel/FSidePanel.form +++ b/comp/src/gb.form/.src/SidePanel/FSidePanel.form @@ -7,7 +7,7 @@ MoveScaled(7,10,35,33) } { panMove Panel - MoveScaled(1,5,46,4) + MoveScaled(1,4,46,4) { btnSide DrawingArea MoveScaled(10,0,6,4) Mouse = Mouse.Pointing diff --git a/comp/src/gb.form/.src/SidePanel/SidePanel.class b/comp/src/gb.form/.src/SidePanel/SidePanel.class index 774e53ee0..af09058f7 100644 --- a/comp/src/gb.form/.src/SidePanel/SidePanel.class +++ b/comp/src/gb.form/.src/SidePanel/SidePanel.class @@ -23,6 +23,7 @@ Property Design As Boolean Property Settings As Variant[] Property Transparent As Boolean Property MinSize As Integer +Private $hObs As Observer Private $hForm As FSidePanel @@ -30,11 +31,19 @@ Public Sub _new() $hForm = New FSidePanel(Me) $hForm.Move(0, 0) + $hObs = New Observer(Me.Parent) As "Observer" 'Object.Attach($hForm, ME, "Form") Me._Container = $hForm.GetContainer() End +Public Sub Observer_Arrange() + + $hForm.RefreshAll + +End + + Private Function Orientation_Read() As Integer Return $hForm.GetOrientation() diff --git a/comp/src/gb.form/.src/Test/FTestArrangement.class b/comp/src/gb.form/.src/Test/FTestArrangement.class new file mode 100644 index 000000000..7ef81b9b0 --- /dev/null +++ b/comp/src/gb.form/.src/Test/FTestArrangement.class @@ -0,0 +1,14 @@ +' Gambas class file + + +Public Sub Form_Open() + + 'Panel2.H = 0 + +End + +Public Sub Form_Arrange() + + Debug Panel2.Y + +End diff --git a/comp/src/gb.form/.src/Test/FTestArrangement.form b/comp/src/gb.form/.src/Test/FTestArrangement.form new file mode 100644 index 000000000..e74c3abfc --- /dev/null +++ b/comp/src/gb.form/.src/Test/FTestArrangement.form @@ -0,0 +1,18 @@ +# Gambas Form File 3.0 + +{ Form Form + MoveScaled(0,0,64,64) + Arrangement = Arrange.Vertical + { Panel1 Panel + MoveScaled(6,5,47,13) + Expand = True + Border = Border.Plain + } + { Panel2 Panel + MoveScaled(6,23,47,13) + Mouse = Mouse.SplitV + } + { Expander1 Expander + MoveScaled(3,42,55,19) + } +} diff --git a/comp/src/gb.form/.src/Test/FTestSidePanel.class b/comp/src/gb.form/.src/Test/FTestSidePanel.class index 0a5fa73ac..863f482a4 100644 --- a/comp/src/gb.form/.src/Test/FTestSidePanel.class +++ b/comp/src/gb.form/.src/Test/FTestSidePanel.class @@ -1,2 +1,20 @@ ' Gambas class file + +Public Sub Form_Open() + + Application.Animations = True + +End + +Public Sub Form_Arrange() + + 'Debug SidePanelBottom.W;; SidePanelBottom._Container.W + +End + +Public Sub Panel1_Arrange() + + 'Debug Panel1.W - Desktop.Scale * 2;; SidePanelBottom.W + +End diff --git a/comp/src/gb.form/.src/Test/FTestSidePanel.form b/comp/src/gb.form/.src/Test/FTestSidePanel.form index 121125dd7..f3b80f272 100644 --- a/comp/src/gb.form/.src/Test/FTestSidePanel.form +++ b/comp/src/gb.form/.src/Test/FTestSidePanel.form @@ -4,19 +4,33 @@ MoveScaled(0,0,104,64) Background = &HFFFF00& Arrangement = Arrange.Horizontal - { SidePanel1 SidePanel + { SidePanelLeft SidePanel MoveScaled(1,2,20,57) Background = &HFFFFFF& Orientation = Align.Left Separator = True - Transparent = True } - { DrawingArea1 DrawingArea - MoveScaled(28,3,51,52) - Background = &H7F7F7F& + { Panel2 Panel + MoveScaled(22,13,4,11) + Background = &HFF7F00& + } + { Panel1 VBox + MoveScaled(28,3,52,56) + Background = &H00FF7F& Expand = True + { DrawingArea1 DrawingArea + MoveScaled(0,0,51,35) + Expand = True + } + { SidePanelBottom SidePanel + MoveScaled(2,41,48,14) + Background = Color.White + Orientation = Align.Bottom + Separator = True + Hidden = True + } } - { SidePanel2 SidePanel + { SidePanelRight SidePanel MoveScaled(87,7,12,48) Orientation = Align.Right Separator = True