<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.vbex.ru/index.php?action=history&amp;feed=atom&amp;title=VB.Net_Tutorial%2FGUI%2FIrregular_Window</id>
		<title>VB.Net Tutorial/GUI/Irregular Window - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.vbex.ru/index.php?action=history&amp;feed=atom&amp;title=VB.Net_Tutorial%2FGUI%2FIrregular_Window"/>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VB.Net_Tutorial/GUI/Irregular_Window&amp;action=history"/>
		<updated>2026-04-05T07:00:49Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.vbex.ru/index.php?title=VB.Net_Tutorial/GUI/Irregular_Window&amp;diff=3778&amp;oldid=prev</id>
		<title> в 16:40, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VB.Net_Tutorial/GUI/Irregular_Window&amp;diff=3778&amp;oldid=prev"/>
				<updated>2010-05-26T16:40:30Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 16:40, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://www.vbex.ru/index.php?title=VB.Net_Tutorial/GUI/Irregular_Window&amp;diff=3779&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VB.Net_Tutorial/GUI/Irregular_Window&amp;diff=3779&amp;oldid=prev"/>
				<updated>2010-05-26T12:56:41Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Drag and drop irregular window==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;vbnet&amp;quot;&amp;gt;Imports System.Drawing&lt;br /&gt;
Imports System.Drawing.Drawing2D&lt;br /&gt;
Imports System.Windows.Forms&lt;br /&gt;
public class TransparentFormDemo&lt;br /&gt;
   public Shared Sub Main&lt;br /&gt;
        Application.Run(New TransparentForm)&lt;br /&gt;
   End Sub&lt;br /&gt;
End class&lt;br /&gt;
Public Class TransparentForm&lt;br /&gt;
    Inherits System.Windows.Forms.Form&lt;br /&gt;
#Region &amp;quot; Windows Form Designer generated code &amp;quot;&lt;br /&gt;
    Public Sub New()&lt;br /&gt;
        MyBase.New()&lt;br /&gt;
        &amp;quot;This call is required by the Windows Form Designer.&lt;br /&gt;
        InitializeComponent()&lt;br /&gt;
        &amp;quot;Add any initialization after the InitializeComponent() call&lt;br /&gt;
        Me.SetStyle(ControlStyles.ResizeRedraw, True)&lt;br /&gt;
    End Sub&lt;br /&gt;
    &amp;quot;Form overrides dispose to clean up the component list.&lt;br /&gt;
    Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)&lt;br /&gt;
        If disposing Then&lt;br /&gt;
            If Not (components Is Nothing) Then&lt;br /&gt;
                components.Dispose()&lt;br /&gt;
            End If&lt;br /&gt;
        End If&lt;br /&gt;
        MyBase.Dispose(disposing)&lt;br /&gt;
    End Sub&lt;br /&gt;
    &amp;quot;Required by the Windows Form Designer&lt;br /&gt;
    Private components As System.ruponentModel.IContainer&lt;br /&gt;
    &amp;quot;NOTE: The following procedure is required by the Windows Form Designer&lt;br /&gt;
    &amp;quot;It can be modified using the Windows Form Designer.  &lt;br /&gt;
    &amp;quot;Do not modify it using the code editor.&lt;br /&gt;
    &amp;lt;System.Diagnostics.DebuggerStepThrough()&amp;gt; Private Sub InitializeComponent()&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;TransparentForm&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.AutoScaleBaseSize = New System.Drawing.Size(5, 13)&lt;br /&gt;
        Me.ClientSize = New System.Drawing.Size(208, 68)&lt;br /&gt;
        Me.FormBorderStyle = System.Windows.Forms.FormBorderStyle.None&lt;br /&gt;
        Me.Name = &amp;quot;TransparentForm&amp;quot;&lt;br /&gt;
        Me.Text = &amp;quot;Transparency Test&amp;quot;&lt;br /&gt;
    End Sub&lt;br /&gt;
#End Region&lt;br /&gt;
    Private Sub TransparentForm_Paint(ByVal sender As Object, ByVal e As System.Windows.Forms.PaintEventArgs) Handles MyBase.Paint&lt;br /&gt;
        Dim g As Graphics = e.Graphics&lt;br /&gt;
        Dim pen As Pen = New Pen(Color.Red, 4)&lt;br /&gt;
        Dim rect As Rectangle = Me.ClientRectangle&lt;br /&gt;
        rect.Inflate(-2, -2)&lt;br /&gt;
        g.FillEllipse(Brushes.Yellow, rect)&lt;br /&gt;
        g.DrawEllipse(pen, rect)&lt;br /&gt;
        pen.Dispose()&lt;br /&gt;
    End Sub&lt;br /&gt;
    Sub SetEllipseRegion()&lt;br /&gt;
        Dim rect As Rectangle = Me.ClientRectangle&lt;br /&gt;
        Dim path As GraphicsPath = New GraphicsPath()&lt;br /&gt;
        path.AddEllipse(RectangleF.op_Implicit(rect))&lt;br /&gt;
        Me.Region = New Region(path)&lt;br /&gt;
        path.Dispose()&lt;br /&gt;
    End Sub&lt;br /&gt;
    Private Sub TransparentForm_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles MyBase.Load&lt;br /&gt;
        SetEllipseRegion()&lt;br /&gt;
    End Sub&lt;br /&gt;
    Private Sub TransparentForm_SizeChanged(ByVal sender As Object, ByVal e As System.EventArgs) Handles MyBase.SizeChanged&lt;br /&gt;
        SetEllipseRegion()&lt;br /&gt;
    End Sub&lt;br /&gt;
    Dim downpoint As Point = Point.Empty&lt;br /&gt;
    Private Sub TransparentForm_MouseDown(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles MyBase.MouseDown&lt;br /&gt;
        If e.Button &amp;lt;&amp;gt; MouseButtons.Left Then Exit Sub&lt;br /&gt;
        downpoint = New Point(e.X, e.Y)&lt;br /&gt;
    End Sub&lt;br /&gt;
    Private Sub TransparentForm_MouseMove(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles MyBase.MouseMove&lt;br /&gt;
        If downpoint = Point.Empty Then Exit Sub&lt;br /&gt;
        Dim location As Point = New Point(me.Left + e.X - downpoint.X, me.Top + e.Y - downpoint.Y)&lt;br /&gt;
        Me.Location = location&lt;br /&gt;
    End Sub&lt;br /&gt;
    Private Sub TransparentForm_MouseUp(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles MyBase.MouseUp&lt;br /&gt;
        If e.Button &amp;lt;&amp;gt; MouseButtons.Left Then Exit Sub&lt;br /&gt;
        downpoint = Point.Empty&lt;br /&gt;
    End Sub&lt;br /&gt;
End Class&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Form Hole==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;vbnet&amp;quot;&amp;gt;Imports System.Windows.Forms&lt;br /&gt;
Imports System.Drawing&lt;br /&gt;
Imports System.Drawing.Drawing2D&lt;br /&gt;
public class FormHole&lt;br /&gt;
   public Shared Sub Main&lt;br /&gt;
        Application.Run(New Form1)&lt;br /&gt;
   End Sub&lt;br /&gt;
End class&lt;br /&gt;
Public Class Form1&lt;br /&gt;
    Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load&lt;br /&gt;
        TransparencyKey = BackColor&lt;br /&gt;
        Label1.BackColor = TransparencyKey&lt;br /&gt;
    End Sub&lt;br /&gt;
    Private Sub Form1_Paint(ByVal sender As Object, ByVal e As System.Windows.Forms.PaintEventArgs) Handles Me.Paint&lt;br /&gt;
        Dim thick_pen As New Pen(Color.Black, 10)&lt;br /&gt;
        Dim rect As New Rectangle( _&lt;br /&gt;
            e.ClipRectangle.X + 10, _&lt;br /&gt;
            e.ClipRectangle.Y + 10, _&lt;br /&gt;
            e.ClipRectangle.Width - 20, _&lt;br /&gt;
            e.ClipRectangle.Height - 20)&lt;br /&gt;
        e.Graphics.DrawEllipse(thick_pen, rect)&lt;br /&gt;
        thick_pen.Dispose()&lt;br /&gt;
    End Sub&lt;br /&gt;
End Class&lt;br /&gt;
&amp;lt;Global.Microsoft.VisualBasic.rupilerServices.DesignerGenerated()&amp;gt; _&lt;br /&gt;
Partial Public Class Form1&lt;br /&gt;
    Inherits System.Windows.Forms.Form&lt;br /&gt;
    &amp;quot;Form overrides dispose to clean up the component list.&lt;br /&gt;
    &amp;lt;System.Diagnostics.DebuggerNonUserCode()&amp;gt; _&lt;br /&gt;
    Protected Overrides Sub Dispose(ByVal disposing As Boolean)&lt;br /&gt;
        If disposing AndAlso components IsNot Nothing Then&lt;br /&gt;
            components.Dispose()&lt;br /&gt;
        End If&lt;br /&gt;
        MyBase.Dispose(disposing)&lt;br /&gt;
    End Sub&lt;br /&gt;
    &amp;quot;Required by the Windows Form Designer&lt;br /&gt;
    Private components As System.ruponentModel.IContainer&lt;br /&gt;
    &amp;quot;NOTE: The following procedure is required by the Windows Form Designer&lt;br /&gt;
    &amp;quot;It can be modified using the Windows Form Designer.  &lt;br /&gt;
    &amp;quot;Do not modify it using the code editor.&lt;br /&gt;
    &amp;lt;System.Diagnostics.DebuggerStepThrough()&amp;gt; _&lt;br /&gt;
    Private Sub InitializeComponent()&lt;br /&gt;
        Me.Label1 = New System.Windows.Forms.Label&lt;br /&gt;
        Me.SuspendLayout()&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;Label1&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.Label1.AutoSize = True&lt;br /&gt;
        Me.Label1.BackColor = System.Drawing.SystemColors.Control&lt;br /&gt;
        Me.Label1.Font = New System.Drawing.Font(&amp;quot;Forte&amp;quot;, 48.0!, System.Drawing.FontStyle.Italic, System.Drawing.GraphicsUnit.Point, CType(0, Byte))&lt;br /&gt;
        Me.Label1.Location = New System.Drawing.Point(48, 56)&lt;br /&gt;
        Me.Label1.Name = &amp;quot;Label1&amp;quot;&lt;br /&gt;
        Me.Label1.Size = New System.Drawing.Size(169, 70)&lt;br /&gt;
        Me.Label1.TabIndex = 0&lt;br /&gt;
        Me.Label1.Text = &amp;quot;Hole&amp;quot;&lt;br /&gt;
        Me.Label1.TextAlign = System.Drawing.ContentAlignment.MiddleCenter&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;Form1&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.AutoScaleDimensions = New System.Drawing.SizeF(6.0!, 13.0!)&lt;br /&gt;
        Me.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font&lt;br /&gt;
        Me.BackColor = System.Drawing.Color.Red&lt;br /&gt;
        Me.ClientSize = New System.Drawing.Size(274, 187)&lt;br /&gt;
        Me.Controls.Add(Me.Label1)&lt;br /&gt;
        Me.Name = &amp;quot;Form1&amp;quot;&lt;br /&gt;
        Me.Text = &amp;quot;Form1&amp;quot;&lt;br /&gt;
        Me.ResumeLayout(False)&lt;br /&gt;
        Me.PerformLayout()&lt;br /&gt;
    End Sub&lt;br /&gt;
    Friend WithEvents Label1 As System.Windows.Forms.Label&lt;br /&gt;
End Class&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Resize irregular window==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;vbnet&amp;quot;&amp;gt;&amp;quot; Quote from&lt;br /&gt;
&amp;quot;Windows Forms Programming in VB&lt;br /&gt;
&amp;quot;by Chris Sells (Author), Justin Gehtland (Author)&lt;br /&gt;
&amp;quot;Publisher: Addison-Wesley Professional; 1st edition (October 24, 2003)&lt;br /&gt;
&amp;quot;Language: English&lt;br /&gt;
&amp;quot;ISBN-10: 0321125193&lt;br /&gt;
&amp;quot;ISBN-13: 978-0321125194&lt;br /&gt;
Imports System.Drawing&lt;br /&gt;
Imports System.Drawing.Drawing2D&lt;br /&gt;
Imports System.Windows.Forms&lt;br /&gt;
public class TransparentFormDemo&lt;br /&gt;
   public Shared Sub Main&lt;br /&gt;
        Application.Run(New TransparentForm)&lt;br /&gt;
   End Sub&lt;br /&gt;
End class&lt;br /&gt;
Public Class TransparentForm&lt;br /&gt;
    Inherits System.Windows.Forms.Form&lt;br /&gt;
#Region &amp;quot; Windows Form Designer generated code &amp;quot;&lt;br /&gt;
    Public Sub New()&lt;br /&gt;
        MyBase.New()&lt;br /&gt;
        &amp;quot;This call is required by the Windows Form Designer.&lt;br /&gt;
        InitializeComponent()&lt;br /&gt;
        &amp;quot;Add any initialization after the InitializeComponent() call&lt;br /&gt;
        Me.SetStyle(ControlStyles.ResizeRedraw, True)&lt;br /&gt;
    End Sub&lt;br /&gt;
    &amp;quot;Form overrides dispose to clean up the component list.&lt;br /&gt;
    Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)&lt;br /&gt;
        If disposing Then&lt;br /&gt;
            If Not (components Is Nothing) Then&lt;br /&gt;
                components.Dispose()&lt;br /&gt;
            End If&lt;br /&gt;
        End If&lt;br /&gt;
        MyBase.Dispose(disposing)&lt;br /&gt;
    End Sub&lt;br /&gt;
    &amp;quot;Required by the Windows Form Designer&lt;br /&gt;
    Private components As System.ruponentModel.IContainer&lt;br /&gt;
    &amp;quot;NOTE: The following procedure is required by the Windows Form Designer&lt;br /&gt;
    &amp;quot;It can be modified using the Windows Form Designer.  &lt;br /&gt;
    &amp;quot;Do not modify it using the code editor.&lt;br /&gt;
    &amp;lt;System.Diagnostics.DebuggerStepThrough()&amp;gt; Private Sub InitializeComponent()&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;TransparentForm&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.AutoScaleBaseSize = New System.Drawing.Size(5, 13)&lt;br /&gt;
        Me.ClientSize = New System.Drawing.Size(208, 68)&lt;br /&gt;
        Me.FormBorderStyle = System.Windows.Forms.FormBorderStyle.None&lt;br /&gt;
        Me.Name = &amp;quot;TransparentForm&amp;quot;&lt;br /&gt;
        Me.Text = &amp;quot;Transparency Test&amp;quot;&lt;br /&gt;
    End Sub&lt;br /&gt;
#End Region&lt;br /&gt;
    Protected Overrides Sub WndProc(ByRef m As System.Windows.Forms.Message)&lt;br /&gt;
        MyBase.WndProc(m)&lt;br /&gt;
        Dim WM_NCHITTEST As Integer = &amp;amp;H84&lt;br /&gt;
        If m.Msg &amp;lt;&amp;gt; WM_NCHITTEST Then Exit Sub&lt;br /&gt;
        Dim HTCLIENT As Integer = 1&lt;br /&gt;
        Dim HTCAPTION As Integer = 2&lt;br /&gt;
        If m.Result.ToInt32() = HTCLIENT Then m.Result = New IntPtr(HTCAPTION)&lt;br /&gt;
        Dim HTLEFT As Integer = 10&lt;br /&gt;
        Dim HTRIGHT As Integer = 11&lt;br /&gt;
        Dim HTTOP As Integer = 12&lt;br /&gt;
        Dim HTTOPLEFT As Integer = 13&lt;br /&gt;
        Dim HTTOPRIGHT As Integer = 14&lt;br /&gt;
        Dim HTBOTTOM As Integer = 15&lt;br /&gt;
        Dim HTBOTTOMLEFT As Integer = 16&lt;br /&gt;
        Dim HTBOTTOMRIGHT As Integer = 17&lt;br /&gt;
        Dim clientLocation As Point = Me.PointToClient(New Point(m.LParam.ToInt32))&lt;br /&gt;
        Dim x As Integer = clientLocation.X &lt;br /&gt;
        Dim y As Integer = clientLocation.Y &lt;br /&gt;
        If x = 0 And y = 0 Then&lt;br /&gt;
            m.Result = New IntPtr(HTCAPTION)&lt;br /&gt;
            Exit Sub&lt;br /&gt;
        ElseIf x = 0 And y &amp;gt;= 0 Then&lt;br /&gt;
            m.Result = New IntPtr(HTRIGHT)&lt;br /&gt;
            Exit Sub&lt;br /&gt;
        ElseIf x = 0 Then&lt;br /&gt;
            m.Result = New IntPtr(HTLEFT)&lt;br /&gt;
            Exit Sub&lt;br /&gt;
        ElseIf y = 0 And x &amp;gt;= 0 Then&lt;br /&gt;
            m.Result = New IntPtr(HTTOP)&lt;br /&gt;
            Exit Sub&lt;br /&gt;
        ElseIf y = 0 Then&lt;br /&gt;
            m.Result = New IntPtr(HTBOTTOM)&lt;br /&gt;
            Exit Sub&lt;br /&gt;
        End If&lt;br /&gt;
        Dim slopeAbs As Double = Math.Abs(CDbl(y) / CDbl(x))&lt;br /&gt;
        If x &amp;gt; 0 And y &amp;gt; 0 Then&lt;br /&gt;
            &amp;quot; Q1&lt;br /&gt;
            If slopeAbs &amp;gt; 2 Then&lt;br /&gt;
                m.Result = New IntPtr(HTTOP)&lt;br /&gt;
            ElseIf slopeAbs &amp;lt; 0.5 Then&lt;br /&gt;
                m.Result = New IntPtr(HTRIGHT)&lt;br /&gt;
            Else&lt;br /&gt;
                m.Result = New IntPtr(HTTOPRIGHT)&lt;br /&gt;
            End If&lt;br /&gt;
        ElseIf x &amp;gt; 0 And y &amp;lt; 0 Then&lt;br /&gt;
            &amp;quot; Q2&lt;br /&gt;
            If slopeAbs &amp;gt; 2 Then&lt;br /&gt;
                m.Result = New IntPtr(HTBOTTOM)&lt;br /&gt;
            ElseIf slopeAbs &amp;lt; 0.5 Then&lt;br /&gt;
                m.Result = New IntPtr(HTRIGHT)&lt;br /&gt;
            Else&lt;br /&gt;
                m.Result = New IntPtr(HTBOTTOMRIGHT)&lt;br /&gt;
            End If&lt;br /&gt;
        ElseIf x &amp;lt; 0 And y &amp;lt; 0 Then&lt;br /&gt;
            &amp;quot; Q3&lt;br /&gt;
            If slopeAbs &amp;gt; 2 Then&lt;br /&gt;
                m.Result = New IntPtr(HTBOTTOM)&lt;br /&gt;
            ElseIf slopeAbs &amp;lt; 0.5 Then&lt;br /&gt;
                m.Result = New IntPtr(HTLEFT)&lt;br /&gt;
            Else&lt;br /&gt;
                m.Result = New IntPtr(HTBOTTOMLEFT)&lt;br /&gt;
            End If&lt;br /&gt;
        Else&lt;br /&gt;
            &amp;quot; Q4&lt;br /&gt;
            If slopeAbs &amp;gt; 2 Then&lt;br /&gt;
                m.Result = New IntPtr(HTTOP)&lt;br /&gt;
            ElseIf slopeAbs &amp;lt; 0.5 Then&lt;br /&gt;
                m.Result = New IntPtr(HTLEFT)&lt;br /&gt;
            Else&lt;br /&gt;
                m.Result = New IntPtr(HTTOPLEFT)&lt;br /&gt;
            End If&lt;br /&gt;
        End If&lt;br /&gt;
    End Sub&lt;br /&gt;
End Class&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>