<?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%2FApplication%2FPainter</id>
		<title>VB.Net/Application/Painter - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.vbex.ru/index.php?action=history&amp;feed=atom&amp;title=VB.Net%2FApplication%2FPainter"/>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VB.Net/Application/Painter&amp;action=history"/>
		<updated>2026-04-05T06:27:23Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.vbex.ru/index.php?title=VB.Net/Application/Painter&amp;diff=6&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/Application/Painter&amp;diff=6&amp;oldid=prev"/>
				<updated>2010-05-26T16:40:06Z</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/Application/Painter&amp;diff=7&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VB.Net/Application/Painter&amp;diff=7&amp;oldid=prev"/>
				<updated>2010-05-26T12:41:31Z</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;==Your own paint==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;vbnet&amp;quot;&amp;gt;&lt;br /&gt;
&amp;quot; Code from Begin VB.net Programming&lt;br /&gt;
Imports System&lt;br /&gt;
Imports System.Collections&lt;br /&gt;
Imports System.Data&lt;br /&gt;
Imports System.IO&lt;br /&gt;
Imports System.Xml.Serialization&lt;br /&gt;
Imports System.Xml&lt;br /&gt;
Imports System.Windows.Forms&lt;br /&gt;
Imports System.Data.SqlClient&lt;br /&gt;
Imports System.Drawing&lt;br /&gt;
Imports System.ruponentModel&lt;br /&gt;
&lt;br /&gt;
Public Class MainClass&lt;br /&gt;
    Shared Sub Main()&lt;br /&gt;
        Dim form1 As Form = New Form1&lt;br /&gt;
        Application.Run(form1)&lt;br /&gt;
    End Sub&lt;br /&gt;
End Class&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Public Class Form1&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;
    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;
    Friend WithEvents canvas As PaintCanvas&lt;br /&gt;
    Friend WithEvents paletteColor As ColorPalette&lt;br /&gt;
    Friend WithEvents mnuMain As System.Windows.Forms.MainMenu&lt;br /&gt;
    Friend WithEvents mnuTools As System.Windows.Forms.MenuItem&lt;br /&gt;
    Friend WithEvents mnuToolsCircle As System.Windows.Forms.MenuItem&lt;br /&gt;
    Friend WithEvents mnuToolsHollowCircle As System.Windows.Forms.MenuItem&lt;br /&gt;
    Friend WithEvents dlgOpenBackground As System.Windows.Forms.OpenFileDialog&lt;br /&gt;
    Friend WithEvents mnuFile As System.Windows.Forms.MenuItem&lt;br /&gt;
    Friend WithEvents mnuFileOpenBackground As System.Windows.Forms.MenuItem&lt;br /&gt;
    &amp;lt;System.Diagnostics.DebuggerStepThrough()&amp;gt; Private Sub InitializeComponent()&lt;br /&gt;
        Me.canvas = New PaintCanvas()&lt;br /&gt;
        Me.paletteColor = New ColorPalette()&lt;br /&gt;
        Me.mnuMain = New System.Windows.Forms.MainMenu()&lt;br /&gt;
        Me.mnuFile = New System.Windows.Forms.MenuItem()&lt;br /&gt;
        Me.mnuFileOpenBackground = New System.Windows.Forms.MenuItem()&lt;br /&gt;
        Me.mnuTools = New System.Windows.Forms.MenuItem()&lt;br /&gt;
        Me.mnuToolsCircle = New System.Windows.Forms.MenuItem()&lt;br /&gt;
        Me.mnuToolsHollowCircle = New System.Windows.Forms.MenuItem()&lt;br /&gt;
        Me.dlgOpenBackground = New System.Windows.Forms.OpenFileDialog()&lt;br /&gt;
        Me.SuspendLayout()&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;canvas&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.canvas.Anchor = (((System.Windows.Forms.AnchorStyles.Top Or System.Windows.Forms.AnchorStyles.Bottom) _&lt;br /&gt;
                    Or System.Windows.Forms.AnchorStyles.Left) _&lt;br /&gt;
                    Or System.Windows.Forms.AnchorStyles.Right)&lt;br /&gt;
        Me.canvas.BackColor = System.Drawing.Color.White&lt;br /&gt;
        Me.canvas.Location = New System.Drawing.Point(4, -4)&lt;br /&gt;
        Me.canvas.Name = &amp;quot;canvas&amp;quot;&lt;br /&gt;
        Me.canvas.Size = New System.Drawing.Size(684, 356)&lt;br /&gt;
        Me.canvas.TabIndex = 0&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;paletteColor&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.paletteColor.Anchor = ((System.Windows.Forms.AnchorStyles.Bottom Or System.Windows.Forms.AnchorStyles.Left) _&lt;br /&gt;
                    Or System.Windows.Forms.AnchorStyles.Right)&lt;br /&gt;
        Me.paletteColor.AutoScroll = True&lt;br /&gt;
        Me.paletteColor.Location = New System.Drawing.Point(0, 356)&lt;br /&gt;
        Me.paletteColor.Name = &amp;quot;paletteColor&amp;quot;&lt;br /&gt;
        Me.paletteColor.Size = New System.Drawing.Size(688, 24)&lt;br /&gt;
        Me.paletteColor.TabIndex = 1&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;mnuMain&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.mnuMain.MenuItems.AddRange(New System.Windows.Forms.MenuItem() {Me.mnuFile, Me.mnuTools})&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;mnuFile&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.mnuFile.Index = 0&lt;br /&gt;
        Me.mnuFile.MenuItems.AddRange(New System.Windows.Forms.MenuItem() {Me.mnuFileOpenBackground})&lt;br /&gt;
        Me.mnuFile.Text = &amp;quot;&amp;amp;File&amp;quot;&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;mnuFileOpenBackground&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.mnuFileOpenBackground.Index = 0&lt;br /&gt;
        Me.mnuFileOpenBackground.Text = &amp;quot;Open &amp;amp;Background Image&amp;quot;&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;mnuTools&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.mnuTools.Index = 1&lt;br /&gt;
        Me.mnuTools.MenuItems.AddRange(New System.Windows.Forms.MenuItem() {Me.mnuToolsCircle, Me.mnuToolsHollowCircle})&lt;br /&gt;
        Me.mnuTools.Text = &amp;quot;&amp;amp;Tools&amp;quot;&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;mnuToolsCircle&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.mnuToolsCircle.Checked = True&lt;br /&gt;
        Me.mnuToolsCircle.Index = 0&lt;br /&gt;
        Me.mnuToolsCircle.Text = &amp;quot;&amp;amp;Circle&amp;quot;&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;mnuToolsHollowCircle&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.mnuToolsHollowCircle.Index = 1&lt;br /&gt;
        Me.mnuToolsHollowCircle.Text = &amp;quot;&amp;amp;Hollow Circle&amp;quot;&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;Form1&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(688, 377)&lt;br /&gt;
        Me.Controls.AddRange(New System.Windows.Forms.Control() {Me.paletteColor, Me.canvas})&lt;br /&gt;
        Me.Menu = Me.mnuMain&lt;br /&gt;
        Me.Name = &amp;quot;Form1&amp;quot;&lt;br /&gt;
        Me.Text = &amp;quot;WroxPaint&amp;quot;&lt;br /&gt;
        Me.ResumeLayout(False)&lt;br /&gt;
    End Sub&lt;br /&gt;
#End Region&lt;br /&gt;
    Private Sub paletteColor_LeftClick(ByVal sender As Object, ByVal e As System.EventArgs) Handles paletteColor.LeftClick&lt;br /&gt;
        canvas.GraphicLeftColor = paletteColor.LeftColor&lt;br /&gt;
    End Sub&lt;br /&gt;
    Private Sub paletteColor_RightClick(ByVal sender As Object, ByVal e As System.EventArgs) Handles paletteColor.RightClick&lt;br /&gt;
        canvas.GraphicRightColor = paletteColor.RightColor&lt;br /&gt;
    End Sub&lt;br /&gt;
    Private Sub mnuToolsCircle_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles mnuToolsCircle.Click&lt;br /&gt;
        canvas.GraphicTool = PaintCanvas.GraphicTools.CirclePen&lt;br /&gt;
        UpdateMenu()&lt;br /&gt;
    End Sub&lt;br /&gt;
    Private Sub mnuToolsHollowCircle_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles mnuToolsHollowCircle.Click&lt;br /&gt;
        canvas.GraphicTool = PaintCanvas.GraphicTools.HollowCirclePen&lt;br /&gt;
        UpdateMenu()&lt;br /&gt;
    End Sub&lt;br /&gt;
    Private Function UpdateMenu()&lt;br /&gt;
        If canvas.GraphicTool = PaintCanvas.GraphicTools.CirclePen Then&lt;br /&gt;
            mnuToolsCircle.Checked = True&lt;br /&gt;
        Else&lt;br /&gt;
            mnuToolsCircle.Checked = False&lt;br /&gt;
        End If&lt;br /&gt;
        If canvas.GraphicTool = PaintCanvas.GraphicTools.HollowCirclePen Then&lt;br /&gt;
            mnuToolsHollowCircle.Checked = True&lt;br /&gt;
        Else&lt;br /&gt;
            mnuToolsHollowCircle.Checked = False&lt;br /&gt;
        End If&lt;br /&gt;
    End Function&lt;br /&gt;
    Private Sub mnuFileOpenBackground_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles mnuFileOpenBackground.Click&lt;br /&gt;
        OpenBackgroundImage()&lt;br /&gt;
    End Sub&lt;br /&gt;
    Public Sub OpenBackgroundImage()&lt;br /&gt;
        If dlgOpenBackground.ShowDialog() = DialogResult.OK Then&lt;br /&gt;
            Dim backgroundImage As Image = _&lt;br /&gt;
               Image.FromFile(dlgOpenBackground.FileName)&lt;br /&gt;
            canvas.BackgroundImage = backgroundImage&lt;br /&gt;
        End If&lt;br /&gt;
    End Sub&lt;br /&gt;
End Class&lt;br /&gt;
&lt;br /&gt;
Public Class PaintCanvas&lt;br /&gt;
    Inherits System.Windows.Forms.UserControl&lt;br /&gt;
    Public Enum GraphicTools As Integer&lt;br /&gt;
        CirclePen = 0&lt;br /&gt;
        HollowCirclePen = 1&lt;br /&gt;
    End Enum&lt;br /&gt;
    Public Enum GraphicSizes As Integer&lt;br /&gt;
        Small = 4&lt;br /&gt;
        Medium = 10&lt;br /&gt;
        Large = 20&lt;br /&gt;
    End Enum&lt;br /&gt;
    Public GraphicsItems As New ArrayList()&lt;br /&gt;
    Public GraphicTool As GraphicTools = GraphicTools.CirclePen&lt;br /&gt;
    Public GraphicSize As GraphicSizes = GraphicSizes.Medium&lt;br /&gt;
    Public GraphicLeftColor As Color = Color.Black&lt;br /&gt;
    Public GraphicRightColor As Color = Color.White&lt;br /&gt;
    Private Sub DoMousePaint(ByVal e As MouseEventArgs)&lt;br /&gt;
        Dim newItem As GraphicsItem&lt;br /&gt;
        Dim useColor As Color = GraphicLeftColor&lt;br /&gt;
        If e.Button = MouseButtons.Right Then useColor = GraphicRightColor&lt;br /&gt;
        Select Case GraphicTool&lt;br /&gt;
        Case GraphicTools.CirclePen, GraphicTools.HollowCirclePen&lt;br /&gt;
                Dim filled As Boolean = True&lt;br /&gt;
                If GraphicTool = GraphicTools.HollowCirclePen Then _&lt;br /&gt;
                   filled = False&lt;br /&gt;
                Dim circle As New GraphicsCircle()&lt;br /&gt;
                circle.SetPoint(e.X, e.Y, GraphicSize, useColor, filled)&lt;br /&gt;
                newItem = circle&lt;br /&gt;
        End Select&lt;br /&gt;
        If Not newItem Is Nothing Then&lt;br /&gt;
            GraphicsItems.Add(newItem)&lt;br /&gt;
            Invalidate(newItem.Rectangle)&lt;br /&gt;
        End If&lt;br /&gt;
    End Sub&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;
    End Sub&lt;br /&gt;
    &amp;quot;UserControl 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;PaintCanvas&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.BackColor = System.Drawing.Color.WhiteSmoke&lt;br /&gt;
        Me.Name = &amp;quot;PaintCanvas&amp;quot;&lt;br /&gt;
    End Sub&lt;br /&gt;
#End Region&lt;br /&gt;
    Protected Overrides Sub OnMouseDown(ByVal e As System.Windows.Forms.MouseEventArgs)&lt;br /&gt;
        If e.Button = MouseButtons.Left Or e.Button = MouseButtons.Right Then&lt;br /&gt;
            DoMousePaint(e)&lt;br /&gt;
        End If&lt;br /&gt;
    End Sub&lt;br /&gt;
    Protected Overrides Sub OnMouseMove(ByVal e As System.Windows.Forms.MouseEventArgs)&lt;br /&gt;
        If e.Button = MouseButtons.Left Or e.Button = MouseButtons.Right Then&lt;br /&gt;
            DoMousePaint(e)&lt;br /&gt;
        End If&lt;br /&gt;
    End Sub&lt;br /&gt;
    Protected Overrides Sub OnPaint(ByVal e As System.Windows.Forms.PaintEventArgs)&lt;br /&gt;
        Dim item As GraphicsItem&lt;br /&gt;
        For Each item In GraphicsItems&lt;br /&gt;
            If e.ClipRectangle.IntersectsWith(item.Rectangle) = True Then&lt;br /&gt;
                item.Draw(e.Graphics)&lt;br /&gt;
            End If&lt;br /&gt;
        Next&lt;br /&gt;
    End Sub&lt;br /&gt;
    Protected Overrides Sub OnPaintBackground(ByVal pevent As System.Windows.Forms.PaintEventArgs)&lt;br /&gt;
        Dim backgroundBrush As New SolidBrush(BackColor)&lt;br /&gt;
        pevent.Graphics.FillRectangle(backgroundBrush, pevent.ClipRectangle)&lt;br /&gt;
        If Not BackgroundImage Is Nothing Then&lt;br /&gt;
            Dim clientRectangle As New Rectangle(0, 0, Width, Height)&lt;br /&gt;
            Dim imageWidth As Integer = BackgroundImage.Width&lt;br /&gt;
            Dim imageHeight As Integer = BackgroundImage.Height&lt;br /&gt;
            Dim ratio As Double = _&lt;br /&gt;
               CType(imageHeight, Double) / CType(imageWidth, Double)&lt;br /&gt;
            If imageWidth &amp;gt; clientRectangle.Width Then&lt;br /&gt;
                imageWidth = clientRectangle.Width&lt;br /&gt;
                imageHeight = CType(CType(imageWidth, Double) * ratio, Integer)&lt;br /&gt;
            Else&lt;br /&gt;
                imageHeight = clientRectangle.Height&lt;br /&gt;
                imageWidth = CType(CType(imageHeight, Double) / ratio, Integer)&lt;br /&gt;
            End If&lt;br /&gt;
            Dim imageLocation As New Point( _&lt;br /&gt;
             (clientRectangle.Width / 2) - (imageWidth / 2), _&lt;br /&gt;
             (clientRectangle.Height / 2) - (imageHeight / 2))&lt;br /&gt;
            Dim imageSize As New Size(imageWidth, imageHeight)&lt;br /&gt;
            Dim imageRectangle As New Rectangle(imageLocation, imageSize)&lt;br /&gt;
            pevent.Graphics.DrawImage(BackgroundImage, imageRectangle)&lt;br /&gt;
        End If&lt;br /&gt;
    End Sub&lt;br /&gt;
    Protected Overrides Sub OnResize(ByVal e As System.EventArgs)&lt;br /&gt;
        Invalidate()&lt;br /&gt;
    End Sub&lt;br /&gt;
End Class&lt;br /&gt;
Public MustInherit Class GraphicsItem&lt;br /&gt;
    Public Color As Color&lt;br /&gt;
    Public IsFilled As Boolean&lt;br /&gt;
    Public Rectangle As Rectangle&lt;br /&gt;
    Public MustOverride Sub Draw(ByVal graphics As Graphics)&lt;br /&gt;
    Public Sub SetPoint(ByVal x As Integer, ByVal y As Integer, _&lt;br /&gt;
       ByVal graphicSize As Integer, _&lt;br /&gt;
       ByVal graphicColor As Color, ByVal graphicIsFilled As Boolean)&lt;br /&gt;
        Rectangle = New _&lt;br /&gt;
           Rectangle(x - (graphicSize / 2), y - (graphicSize / 2), _&lt;br /&gt;
           graphicSize, graphicSize)&lt;br /&gt;
        Color = graphicColor&lt;br /&gt;
        IsFilled = graphicIsFilled&lt;br /&gt;
    End Sub&lt;br /&gt;
End Class&lt;br /&gt;
Public Class GraphicsCircle&lt;br /&gt;
    Inherits GraphicsItem&lt;br /&gt;
    Public Overrides Sub Draw(ByVal graphics As _&lt;br /&gt;
           System.Drawing.Graphics)&lt;br /&gt;
        If IsFilled = True Then&lt;br /&gt;
            Dim brush As New SolidBrush(Me.Color)&lt;br /&gt;
            graphics.FillEllipse(brush, Me.Rectangle)&lt;br /&gt;
        Else&lt;br /&gt;
            Dim pen As New Pen(Me.Color)&lt;br /&gt;
            Dim drawRectangle As Rectangle = Me.Rectangle&lt;br /&gt;
            drawRectangle.Inflate(-1, -1)&lt;br /&gt;
            graphics.DrawEllipse(pen, drawRectangle)&lt;br /&gt;
        End If&lt;br /&gt;
    End Sub&lt;br /&gt;
End Class&lt;br /&gt;
Public Class ColorPaletteButton&lt;br /&gt;
    Public Color As Color = Color.Black&lt;br /&gt;
    Public Rectangle As Rectangle&lt;br /&gt;
    Public ButtonAssignment As ButtonAssignments = ButtonAssignments.None&lt;br /&gt;
    Public Enum ButtonAssignments As Integer&lt;br /&gt;
        None = 0&lt;br /&gt;
        LeftButton = 1&lt;br /&gt;
        RightButton = 2&lt;br /&gt;
    End Enum&lt;br /&gt;
    Public Sub New(ByVal newColor As Color)&lt;br /&gt;
        Color = newColor&lt;br /&gt;
    End Sub&lt;br /&gt;
    Public Sub SetPosition(ByVal x As Integer, ByVal y As Integer, _&lt;br /&gt;
                        ByVal buttonSize As Integer)&lt;br /&gt;
        Rectangle = New Rectangle(x, y, buttonSize, buttonSize)&lt;br /&gt;
    End Sub&lt;br /&gt;
    Public Sub Draw(ByVal graphics As Graphics)&lt;br /&gt;
        Dim brush As New SolidBrush(Color)&lt;br /&gt;
        graphics.FillRectangle(brush, Rectangle)&lt;br /&gt;
        Dim pen As New Pen(Color.Black)&lt;br /&gt;
        graphics.DrawRectangle(pen, Rectangle)&lt;br /&gt;
        If ButtonAssignment &amp;lt;&amp;gt; ButtonAssignments.None Then&lt;br /&gt;
            Dim font As New Font(&amp;quot;verdana&amp;quot;, 8, FontStyle.Bold)&lt;br /&gt;
            Dim buttonText As String = &amp;quot;L&amp;quot;&lt;br /&gt;
            If ButtonAssignment = ButtonAssignments.RightButton Then _&lt;br /&gt;
                              buttonText = &amp;quot;R&amp;quot;&lt;br /&gt;
            Dim fontBrush As SolidBrush&lt;br /&gt;
            If Color.R &amp;lt; 100 Or Color.B &amp;lt; 100 Or Color.G &amp;lt; 100 Then&lt;br /&gt;
                fontBrush = New SolidBrush(Color.White)&lt;br /&gt;
            Else&lt;br /&gt;
                fontBrush = New SolidBrush(Color.Black)&lt;br /&gt;
            End If&lt;br /&gt;
            graphics.DrawString(buttonText, font, fontBrush, _&lt;br /&gt;
                  Rectangle.Left, Rectangle.Top)&lt;br /&gt;
        End If&lt;br /&gt;
    End Sub&lt;br /&gt;
End Class&lt;br /&gt;
Public Class ColorPalette&lt;br /&gt;
    Inherits System.Windows.Forms.UserControl&lt;br /&gt;
    Public Buttons As New ArrayList()&lt;br /&gt;
    Public ButtonSize As Integer = 15&lt;br /&gt;
    Public ButtonSpacing As Integer = 5&lt;br /&gt;
    Public LeftColor As Color = Color.Black&lt;br /&gt;
    Public RightColor As Color = Color.White&lt;br /&gt;
    Private leftButton As ColorPaletteButton&lt;br /&gt;
    Private rightButton As ColorPaletteButton&lt;br /&gt;
    Event LeftClick(ByVal sender As Object, ByVal e As EventArgs)&lt;br /&gt;
    Event RightClick(ByVal sender As Object, ByVal e As EventArgs)&lt;br /&gt;
    Public Function GetButtonAt(ByVal x As Integer, ByVal y As Integer) _&lt;br /&gt;
                           As ColorPaletteButton&lt;br /&gt;
        Dim button As ColorPaletteButton&lt;br /&gt;
        For Each button In Buttons&lt;br /&gt;
            If button.Rectangle.Contains(x, y) = True Then Return button&lt;br /&gt;
        Next&lt;br /&gt;
    End Function&lt;br /&gt;
    Public Function AddColor(ByVal newColor As Color) As _&lt;br /&gt;
           ColorPaletteButton&lt;br /&gt;
        Dim button As New ColorPaletteButton(newColor)&lt;br /&gt;
        Buttons.Add(button)&lt;br /&gt;
    End Function&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;
        &amp;quot; add the colors...&lt;br /&gt;
        AddColor(Color.Black)&lt;br /&gt;
        AddColor(Color.White)&lt;br /&gt;
        AddColor(Color.Red)&lt;br /&gt;
        AddColor(Color.Blue)&lt;br /&gt;
        AddColor(Color.Green)&lt;br /&gt;
        AddColor(Color.Gray)&lt;br /&gt;
        AddColor(Color.DarkRed)&lt;br /&gt;
        AddColor(Color.DarkBlue)&lt;br /&gt;
        AddColor(Color.DarkGreen)&lt;br /&gt;
        AddColor(Color.DarkGray)&lt;br /&gt;
        AddColor(Color.FromArgb(208, 112, 222))&lt;br /&gt;
        AddColor(CType(SystemBrushes.ActiveCaption, SolidBrush).Color)&lt;br /&gt;
    End Sub&lt;br /&gt;
    &amp;quot;UserControl 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;
    Friend WithEvents dlgColor As System.Windows.Forms.ColorDialog&lt;br /&gt;
    &amp;lt;System.Diagnostics.DebuggerStepThrough()&amp;gt; Private Sub InitializeComponent()&lt;br /&gt;
        Me.dlgColor = New System.Windows.Forms.ColorDialog()&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        &amp;quot;ColorPalette&lt;br /&gt;
        &amp;quot;&lt;br /&gt;
        Me.Name = &amp;quot;ColorPalette&amp;quot;&lt;br /&gt;
    End Sub&lt;br /&gt;
#End Region&lt;br /&gt;
    Protected Overrides Sub OnResize(ByVal e As System.EventArgs)&lt;br /&gt;
        Dim x As Integer, y As Integer&lt;br /&gt;
        Dim button As ColorPaletteButton&lt;br /&gt;
        For Each button In Buttons&lt;br /&gt;
            button.SetPosition(x, y, ButtonSize)&lt;br /&gt;
            x += (ButtonSize + ButtonSpacing)&lt;br /&gt;
            If x + ButtonSize &amp;gt; Width Then&lt;br /&gt;
                y += (ButtonSize + ButtonSpacing)&lt;br /&gt;
                x = 0&lt;br /&gt;
            End If&lt;br /&gt;
        Next&lt;br /&gt;
        Invalidate()&lt;br /&gt;
    End Sub&lt;br /&gt;
    Protected Overrides Sub OnPaint(ByVal e As System.Windows.Forms.PaintEventArgs)&lt;br /&gt;
        Dim button As ColorPaletteButton&lt;br /&gt;
        For Each button In Buttons&lt;br /&gt;
            If e.ClipRectangle.IntersectsWith(button.Rectangle) Then&lt;br /&gt;
                button.Draw(e.Graphics)&lt;br /&gt;
            End If&lt;br /&gt;
        Next&lt;br /&gt;
    End Sub&lt;br /&gt;
    Protected Overrides Sub OnMouseUp(ByVal e As System.Windows.Forms.MouseEventArgs)&lt;br /&gt;
        Dim button As ColorPaletteButton = GetButtonAt(e.X, e.Y)&lt;br /&gt;
        If Not button Is Nothing Then&lt;br /&gt;
            If e.Button = MouseButtons.Left Then&lt;br /&gt;
                If Not button Is rightButton Then&lt;br /&gt;
                    LeftColor = button.Color&lt;br /&gt;
                    If Not leftButton Is Nothing Then&lt;br /&gt;
                        leftButton.ButtonAssignment = _&lt;br /&gt;
                            ColorPaletteButton.ButtonAssignments.None&lt;br /&gt;
                        Invalidate(leftButton.Rectangle)&lt;br /&gt;
                    End If&lt;br /&gt;
                    button.ButtonAssignment = _&lt;br /&gt;
                        ColorPaletteButton.ButtonAssignments.LeftButton&lt;br /&gt;
                    Invalidate(button.Rectangle)&lt;br /&gt;
                    leftButton = button&lt;br /&gt;
                    RaiseEvent LeftClick(Me, New EventArgs())&lt;br /&gt;
                End If&lt;br /&gt;
            End If&lt;br /&gt;
            If e.Button = MouseButtons.Right Then&lt;br /&gt;
                If Not button Is leftButton Then&lt;br /&gt;
                    RightColor = button.Color&lt;br /&gt;
                    If Not rightButton Is Nothing Then&lt;br /&gt;
                        rightButton.ButtonAssignment = _&lt;br /&gt;
                            ColorPaletteButton.ButtonAssignments.None&lt;br /&gt;
                        Invalidate(rightButton.Rectangle)&lt;br /&gt;
                    End If&lt;br /&gt;
                    button.ButtonAssignment = _&lt;br /&gt;
                        ColorPaletteButton.ButtonAssignments.RightButton&lt;br /&gt;
                    Invalidate(button.Rectangle)&lt;br /&gt;
                    rightButton = button&lt;br /&gt;
                    RaiseEvent RightClick(Me, New EventArgs())&lt;br /&gt;
                End If&lt;br /&gt;
            End If&lt;br /&gt;
        Else&lt;br /&gt;
            If dlgColor.ShowDialog = DialogResult.OK Then&lt;br /&gt;
                AddColor(dlgColor.Color)&lt;br /&gt;
                OnResize(New EventArgs())&lt;br /&gt;
            End If&lt;br /&gt;
&lt;br /&gt;
        End If&lt;br /&gt;
    End Sub&lt;br /&gt;
End Class&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>