<?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_by_API%2FSystem.Drawing.Drawing2D%2FMatrix</id>
		<title>VB.Net by API/System.Drawing.Drawing2D/Matrix - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.vbex.ru/index.php?action=history&amp;feed=atom&amp;title=VB.Net_by_API%2FSystem.Drawing.Drawing2D%2FMatrix"/>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VB.Net_by_API/System.Drawing.Drawing2D/Matrix&amp;action=history"/>
		<updated>2026-04-05T22:05:11Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.vbex.ru/index.php?title=VB.Net_by_API/System.Drawing.Drawing2D/Matrix&amp;diff=2587&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_by_API/System.Drawing.Drawing2D/Matrix&amp;diff=2587&amp;oldid=prev"/>
				<updated>2010-05-26T16:40:16Z</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_by_API/System.Drawing.Drawing2D/Matrix&amp;diff=2588&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VB.Net_by_API/System.Drawing.Drawing2D/Matrix&amp;diff=2588&amp;oldid=prev"/>
				<updated>2010-05-26T12:51:18Z</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;==Matrix.Elements==&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;
Imports System.Drawing&lt;br /&gt;
Imports System.Drawing.Drawing2D&lt;br /&gt;
Imports System.Windows.Forms&lt;br /&gt;
public class Test&lt;br /&gt;
   public Shared Sub Main&lt;br /&gt;
        Dim X As New Matrix(2, 1, 3, 1, 0, 4)&lt;br /&gt;
        Dim i As Integer&lt;br /&gt;
        For i = 0 To X.Elements.Length - 1&lt;br /&gt;
            Console.WriteLine(X.Elements(i))&lt;br /&gt;
        Next i&lt;br /&gt;
        Console.WriteLine(&amp;quot;Inverted values: &amp;quot;)&lt;br /&gt;
        X.Invert()&lt;br /&gt;
        Dim pts As Single() = X.Elements&lt;br /&gt;
        Dim i1 As Integer&lt;br /&gt;
        For i = 0 To pts.Length - 1&lt;br /&gt;
            Console.WriteLine(pts(i))&lt;br /&gt;
        Next i&lt;br /&gt;
   End Sub&lt;br /&gt;
End class&lt;br /&gt;
   &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Matrix.Invert==&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;
Imports System.Drawing&lt;br /&gt;
Imports System.Drawing.Drawing2D&lt;br /&gt;
Imports System.Windows.Forms&lt;br /&gt;
public class MatrixReflection&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;
  Inherits System.Windows.Forms.Form&lt;br /&gt;
  Protected Overrides Sub OnPaint(ByVal e As PaintEventArgs)&lt;br /&gt;
        Dim g As Graphics = Me.CreateGraphics()&lt;br /&gt;
        g.Clear(Me.BackColor)&lt;br /&gt;
        Dim curBitmap As New Bitmap(&amp;quot;yourfile.jpg&amp;quot;) &amp;quot;&lt;br /&gt;
        Dim X As New Matrix&lt;br /&gt;
        X.Invert()&lt;br /&gt;
        g.Transform = X&lt;br /&gt;
        g.DrawImage(curBitmap, New Rectangle(0, 0, 200, 200), 0, 0, curBitmap.Width, curBitmap.Height, GraphicsUnit.Pixel)&lt;br /&gt;
        &amp;quot; Dispose&lt;br /&gt;
        curBitmap.Dispose()&lt;br /&gt;
        g.Dispose()&lt;br /&gt;
  End Sub&lt;br /&gt;
  Public Sub New()&lt;br /&gt;
   &lt;br /&gt;
    MyBase.New()&lt;br /&gt;
    Me.AutoScaleBaseSize = New System.Drawing.Size(5, 13)&lt;br /&gt;
    Me.ClientSize = New System.Drawing.Size(292, 273)&lt;br /&gt;
    Me.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen&lt;br /&gt;
  End Sub&lt;br /&gt;
End Class&lt;br /&gt;
   &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Matrix.Multiply==&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;
Imports System.Drawing&lt;br /&gt;
Imports System.Drawing.Drawing2D&lt;br /&gt;
Imports System.Windows.Forms&lt;br /&gt;
public class Test&lt;br /&gt;
   public Shared Sub Main&lt;br /&gt;
        Dim X As New Matrix(2.0F, 1.0F, 3.0F, 1.0F, 0.0F, 4.0F)&lt;br /&gt;
        Dim Y As New Matrix(0.0F, 1.0F, -1.0F, 0.0F, 0.0F, 0.0F)&lt;br /&gt;
        X.Multiply(Y, MatrixOrder.Append)&lt;br /&gt;
        &amp;quot; Read the result Matrix&lt;br /&gt;
        Dim i As Integer&lt;br /&gt;
        For i = 0 To X.Elements.Length - 1&lt;br /&gt;
            Console.WriteLine(X.Elements(i).ToString())&lt;br /&gt;
        Next i&lt;br /&gt;
&lt;br /&gt;
   End Sub&lt;br /&gt;
End class&lt;br /&gt;
   &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Matrix.Rotate==&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;
Imports System&lt;br /&gt;
Imports System.Windows.Forms&lt;br /&gt;
Imports System.Drawing&lt;br /&gt;
Imports System.Drawing.Drawing2D&lt;br /&gt;
Imports System.Drawing.Text&lt;br /&gt;
Imports System.Drawing.Imaging&lt;br /&gt;
Public Class MainClass&lt;br /&gt;
  Shared Sub Main()&lt;br /&gt;
    Dim m As Matrix = New Matrix()&lt;br /&gt;
    m.Rotate(90, MatrixOrder.Append)&lt;br /&gt;
    m.Translate(7, 12, MatrixOrder.Append)&lt;br /&gt;
    Dim p() As Point = {New Point(20, 45)}&lt;br /&gt;
    Console.WriteLine(p.GetValue(0).ToString())&lt;br /&gt;
    m.TransformPoints(p)&lt;br /&gt;
    Console.WriteLine(p.GetValue(0).ToString())&lt;br /&gt;
  End Sub&lt;br /&gt;
  &lt;br /&gt;
End Class&lt;br /&gt;
   &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Matrix.RotateAt==&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;
Imports System.Drawing&lt;br /&gt;
Imports System.Drawing.Drawing2D&lt;br /&gt;
Imports System.Windows.Forms&lt;br /&gt;
public class MatrixRotateAt&lt;br /&gt;
   public Shared Sub Main&lt;br /&gt;
        Application.Run(New RotateForm)&lt;br /&gt;
   End Sub&lt;br /&gt;
End class&lt;br /&gt;
&lt;br /&gt;
Public Class RotateForm&lt;br /&gt;
    Inherits System.Windows.Forms.Form&lt;br /&gt;
    Public Sub New()&lt;br /&gt;
        MyBase.New()&lt;br /&gt;
        Me.AutoScaleBaseSize = New System.Drawing.Size(5, 13)&lt;br /&gt;
        Me.ClientSize = New System.Drawing.Size(280, 214)&lt;br /&gt;
        Me.Name = &amp;quot;RotateForm&amp;quot;&lt;br /&gt;
        Me.Text = &amp;quot;RotateForm&amp;quot;&lt;br /&gt;
    End Sub&lt;br /&gt;
    Sub RotateForm_Paint(ByVal sender As Object, ByVal e As PaintEventArgs) Handles MyBase.Paint&lt;br /&gt;
        Dim g As Graphics = e.Graphics&lt;br /&gt;
        Dim x As Integer = 400&lt;br /&gt;
        Dim y As Integer = 400&lt;br /&gt;
        Dim width As Integer = 250&lt;br /&gt;
        Dim height As Integer = 250&lt;br /&gt;
        Dim textWidth As Single = g.MeasureString(&amp;quot;00&amp;quot;, Me.Font).Width&lt;br /&gt;
        Dim length As Single = 250&lt;br /&gt;
        Dim textRect As RectangleF = New RectangleF(x + length, y - Me.Font.GetHeight(g) / 2, length, textWidth)&lt;br /&gt;
        Dim format As StringFormat = New StringFormat()&lt;br /&gt;
        format.Alignment = StringAlignment.Near&lt;br /&gt;
        format.LineAlignment = StringAlignment.Center&lt;br /&gt;
        Dim i As Integer&lt;br /&gt;
        For i = 0 To 360 Step 5&lt;br /&gt;
            Dim matrix As Matrix = New Matrix()&lt;br /&gt;
            matrix.RotateAt(i, New PointF(x, y))&lt;br /&gt;
            g.Transform = matrix&lt;br /&gt;
            g.DrawLine(Pens.Black, x, y, x + length, y)&lt;br /&gt;
            g.DrawString(i.ToString(), Me.Font, Brushes.Black, textRect, format)&lt;br /&gt;
        Next&lt;br /&gt;
    End Sub&lt;br /&gt;
End Class&lt;br /&gt;
   &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Matrix.Shear==&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;
Imports System.Drawing&lt;br /&gt;
Imports System.Drawing.Drawing2D&lt;br /&gt;
Imports System.Windows.Forms&lt;br /&gt;
public class TransformPathGradientBrush&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;
  Inherits System.Windows.Forms.Form&lt;br /&gt;
  Protected Overrides Sub OnPaint(ByVal e As PaintEventArgs)&lt;br /&gt;
        Dim g As Graphics = Me.CreateGraphics()&lt;br /&gt;
        g.Clear(Me.BackColor)&lt;br /&gt;
        Dim path As New GraphicsPath&lt;br /&gt;
        Dim rect As New Rectangle(20, 20, 200, 200)&lt;br /&gt;
        path.AddRectangle(rect)&lt;br /&gt;
        Dim pgBrush As New PathGradientBrush(path.PathPoints)&lt;br /&gt;
        pgBrush.CenterColor = Color.Green&lt;br /&gt;
        pgBrush.SurroundColors = New Color() {Color.Blue}&lt;br /&gt;
        Dim M As New Matrix&lt;br /&gt;
        M.Translate(20.0F, 10.0F, MatrixOrder.Prepend)&lt;br /&gt;
        M.Rotate(10.0F, MatrixOrder.Prepend)&lt;br /&gt;
        M.Scale(2, 1, MatrixOrder.Prepend)&lt;br /&gt;
        M.Shear(0.05F, 0.03F, MatrixOrder.Prepend)&lt;br /&gt;
        pgBrush.MultiplyTransform(M)&lt;br /&gt;
        g.FillRectangle(pgBrush, 20, 100, 400, 400)&lt;br /&gt;
        pgBrush.Dispose()&lt;br /&gt;
        g.Dispose()&lt;br /&gt;
&lt;br /&gt;
  End Sub&lt;br /&gt;
  Public Sub New()&lt;br /&gt;
   &lt;br /&gt;
    MyBase.New()&lt;br /&gt;
    Me.AutoScaleBaseSize = New System.Drawing.Size(5, 13)&lt;br /&gt;
    Me.ClientSize = New System.Drawing.Size(292, 273)&lt;br /&gt;
    Me.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen&lt;br /&gt;
  End Sub&lt;br /&gt;
End Class&lt;br /&gt;
   &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Matrix.TransformPoints==&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;
Imports System&lt;br /&gt;
Imports System.Windows.Forms&lt;br /&gt;
Imports System.Drawing&lt;br /&gt;
Imports System.Drawing.Drawing2D&lt;br /&gt;
Imports System.Drawing.Text&lt;br /&gt;
Imports System.Drawing.Imaging&lt;br /&gt;
Public Class MainClass&lt;br /&gt;
  Shared Sub Main()&lt;br /&gt;
    Dim m As Matrix = New Matrix()&lt;br /&gt;
    m.Rotate(90, MatrixOrder.Append)&lt;br /&gt;
    m.Translate(7, 12, MatrixOrder.Append)&lt;br /&gt;
    Dim p() As Point = {New Point(20, 45)}&lt;br /&gt;
    Console.WriteLine(p.GetValue(0).ToString())&lt;br /&gt;
    m.TransformPoints(p)&lt;br /&gt;
    Console.WriteLine(p.GetValue(0).ToString())&lt;br /&gt;
  End Sub&lt;br /&gt;
  &lt;br /&gt;
End Class&lt;br /&gt;
   &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Matrix.Translate(Int x, Int y)==&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;
Imports System.Drawing&lt;br /&gt;
Imports System.Drawing.Drawing2D&lt;br /&gt;
Imports System.Windows.Forms&lt;br /&gt;
public class MatrixTranslationDemo&lt;br /&gt;
   public Shared Sub Main&lt;br /&gt;
        Application.Run(New TranslationForm)&lt;br /&gt;
   End Sub&lt;br /&gt;
End class&lt;br /&gt;
Public Class TranslationForm&lt;br /&gt;
    Inherits System.Windows.Forms.Form&lt;br /&gt;
    Public Sub New()&lt;br /&gt;
        MyBase.New()&lt;br /&gt;
    End Sub&lt;br /&gt;
    Sub TranlationForm_Pain(ByVal sender As Object, ByVal e As PaintEventArgs) Handles MyBase.Paint&lt;br /&gt;
        Dim g As Graphics = e.Graphics&lt;br /&gt;
        Dim rect As RectangleF = New RectangleF(0, 0, 125, 125)&lt;br /&gt;
        g.FillRectangle(Brushes.White, rect)&lt;br /&gt;
        g.DrawRectangle(Pens.Black, rect.X, rect.Y, rect.Width, rect.Height)&lt;br /&gt;
        Dim matrix As Matrix = New Matrix()&lt;br /&gt;
        matrix.Translate(150, 150)&lt;br /&gt;
        g.Transform = matrix&lt;br /&gt;
        g.FillRectangle(Brushes.White, rect)&lt;br /&gt;
        g.DrawRectangle(Pens.Black, rect.X, rect.Y, rect.Width, rect.Height)&lt;br /&gt;
    End Sub&lt;br /&gt;
End Class&lt;br /&gt;
   &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>