Windows: Improve Animator

This commit is contained in:
Jonathan Jenne 2021-03-03 09:18:39 +01:00
parent cd75459a27
commit b759d18b6b
4 changed files with 55 additions and 41 deletions

View File

@ -1,51 +1,63 @@
Imports System.Drawing
Imports System.Windows.Forms
Public Class Animator
Public Const DEFAULT_FONT_OPACITY = 0.5
Public Const DEFAULT_FORM_SIZE = 30
Public Const DEFAULT_FORM_FADE_SPEED = 10
Public Const DEFAULT_FORM_FADE_INTERVAL = 250
Private Const DEFAULT_POPUP_OPACITY = 0.5
Private Const DEFAULT_POPUP_SIZE = 30
Private Const DEFAULT_POPUP_FADE_SPEED = 10
Private Const DEFAULT_POPUP_FADE_INTERVAL = 250
Public Property FormSize As Integer
Public Property FadeInterval As Integer
Public Property FadeSpeed As Integer
Public Property FormOpacity As Double
Public Property FormColor As Color
''' <summary>
''' Time the popup stays visible between the animations
''' </summary>
Public Property AnimationInterval As Integer
''' <summary>
''' Basevalue for calculating the time the popup takes to animate
''' </summary>
Public Property AnimationSpeed As Integer
''' <summary>
''' Opacity the popup animates to (From 0.0 to .., back to 0.0)
''' </summary>
Public Property PopupOpacity As Double
''' <summary>
''' Color of the popup
''' </summary>
''' <returns></returns>
Public Property PopupColor As Color
''' <summary>
''' Size of the popup in width and height
''' </summary>
Public Property PopupSize As Size
Public Sub New()
_FormSize = DEFAULT_FORM_SIZE
_FadeSpeed = DEFAULT_FORM_FADE_SPEED
_FadeInterval = DEFAULT_FORM_FADE_INTERVAL
_FormOpacity = DEFAULT_FONT_OPACITY
_FormColor = Color.FromArgb(255, 214, 49)
_PopupSize = New Size(DEFAULT_POPUP_SIZE, DEFAULT_POPUP_SIZE)
_AnimationSpeed = DEFAULT_POPUP_FADE_SPEED
_AnimationInterval = DEFAULT_POPUP_FADE_INTERVAL
_PopupOpacity = DEFAULT_POPUP_OPACITY
_PopupColor = Color.FromArgb(255, 214, 49)
End Sub
Public Sub Highlight(Position As Point)
Dim oForm = GetPopup(Position)
Dim oForm = GetPopup(Position, PopupSize)
oForm.Show()
FadeIn(oForm, _FormOpacity, _FadeSpeed / 2)
Dim oTimer As New Timer With {.Interval = _FadeInterval}
AddHandler oTimer.Tick, Sub()
FadeOut(oForm, _FadeSpeed * 2)
oTimer.Stop()
End Sub
oTimer.Start()
FadeIn(oForm, _PopupOpacity, _AnimationSpeed / 2)
Task.Delay(_AnimationInterval)
FadeOut(oForm, _AnimationSpeed * 2)
End Sub
Private Function GetPopup(CursorPosition As Point) As frmPopup
Dim oFormLocation = New Point(CursorPosition.X - (_FormSize / 2), CursorPosition.Y - (_FormSize / 2))
Dim oFormSize = New Size(_FormSize, _FormSize)
Private Function GetPopup(CursorPosition As Point, PopupSize As Size) As frmPopup
Dim oFormLocation = New Point(
CursorPosition.X - (PopupSize.Width / 2),
CursorPosition.Y - (PopupSize.Height / 2))
Return New frmPopup() With {
.Location = oFormLocation,
.StartPosition = FormStartPosition.Manual,
.Size = oFormSize,
.MaximumSize = oFormSize,
.MinimumSize = oFormSize,
.Size = PopupSize,
.MaximumSize = PopupSize,
.MinimumSize = PopupSize,
.Opacity = 0,
.ShowInTaskbar = False,
.BackColor = _FormColor
.BackColor = _PopupColor
}
End Function
@ -53,7 +65,6 @@ Public Class Animator
While o.Opacity < finalOpacity
Await Task.Delay(interval)
o.Opacity += 0.05
Debug.WriteLine("Fading in, Opacity: " & o.Opacity)
End While
o.Opacity = finalOpacity
@ -63,10 +74,8 @@ Public Class Animator
While o.Opacity > 0.0
Await Task.Delay(interval)
o.Opacity -= 0.05
Debug.WriteLine("Fading out, Opacity: " & o.Opacity)
End While
o.Opacity = 0
End Sub
End Class

View File

@ -1,6 +1,8 @@
<Global.Microsoft.VisualBasic.CompilerServices.DesignerGenerated()> _
Imports System.Windows.Forms
<Global.Microsoft.VisualBasic.CompilerServices.DesignerGenerated()>
Partial Class frmPopup
Inherits System.Windows.Forms.Form
Inherits Form
'Das Formular überschreibt den Löschvorgang, um die Komponentenliste zu bereinigen.
<System.Diagnostics.DebuggerNonUserCode()> _

View File

@ -22,7 +22,7 @@ Namespace My.Resources
'''<summary>
''' Eine stark typisierte Ressourcenklasse zum Suchen von lokalisierten Zeichenfolgen usw.
'''</summary>
<Global.System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "15.0.0.0"), _
<Global.System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "16.0.0.0"), _
Global.System.Diagnostics.DebuggerNonUserCodeAttribute(), _
Global.System.Runtime.CompilerServices.CompilerGeneratedAttribute(), _
Global.Microsoft.VisualBasic.HideModuleNameAttribute()> _

View File

@ -46,7 +46,7 @@
mimetype: application/x-microsoft.net.object.binary.base64
value : The object must be serialized with
: System.Serialization.Formatters.Binary.BinaryFormatter
: System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
: and then encoded with base64 encoding.
mimetype: application/x-microsoft.net.object.soap.base64
@ -60,6 +60,7 @@
: and then encoded with base64 encoding.
-->
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
<xsd:element name="root" msdata:IsDataSet="true">
<xsd:complexType>
<xsd:choice maxOccurs="unbounded">
@ -68,9 +69,10 @@
<xsd:sequence>
<xsd:element name="value" type="xsd:string" minOccurs="0" />
</xsd:sequence>
<xsd:attribute name="name" type="xsd:string" />
<xsd:attribute name="name" use="required" type="xsd:string" />
<xsd:attribute name="type" type="xsd:string" />
<xsd:attribute name="mimetype" type="xsd:string" />
<xsd:attribute ref="xml:space" />
</xsd:complexType>
</xsd:element>
<xsd:element name="assembly">
@ -85,9 +87,10 @@
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
</xsd:sequence>
<xsd:attribute name="name" type="xsd:string" msdata:Ordinal="1" />
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
<xsd:attribute ref="xml:space" />
</xsd:complexType>
</xsd:element>
<xsd:element name="resheader">
@ -109,9 +112,9 @@
<value>2.0</value>
</resheader>
<resheader name="reader">
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
</resheader>
<resheader name="writer">
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
</resheader>
</root>