Аффинные преобразования в пространстве. Простейшие аффинные преобразования в пространстве: перенос, сдвиг, поворот, масштабирование, страница 3

g.DrawLine(figur, scr_points[2], scr_points[3]);

g.DrawLine(figur, scr_points[0], scr_points[4]);

g.DrawLine(figur, scr_points[1], scr_points[5]);

g.DrawLine(figur, scr_points[2], scr_points[6]);

g.DrawLine(figur, scr_points[3], scr_points[7]);

g.DrawLine(figur, scr_points[4], scr_points[5]);

g.DrawLine(figur, scr_points[5], scr_points[6]);

g.DrawLine(figur, scr_points[4], scr_points[7]);

g.DrawLine(figur, scr_points[7], scr_points[6]);

}

//обновление после масштабирования изображения

private void btn_update_Click(object sender, EventArgs e)

{

this.pnlXOY.Invalidate();

this.pnlXOZ.Invalidate();

this.pnlYOZ.Invalidate();

}

//сдвиг по оси X влево

private void btnXdown_Click(object sender, EventArgs e)

{

if (rdbtnXOY.Checked)

{

centerXOY.X += dkx;

this.pnlXOY.Invalidate();

}

if (rdbtnXOZ.Checked)

{

centerXOZ.X += dkx;

this.pnlXOZ.Invalidate();

}

if (rdbtnYOZ.Checked)

{

centerYOZ.X += dkx;

this.pnlYOZ.Invalidate();

}

}

//сдвиг по оси X вправо

private void btnXup_Click(object sender, EventArgs e)

{

if (rdbtnXOY.Checked)

{

centerXOY.X -= dkx;

this.pnlXOY.Invalidate();

}

if (rdbtnXOZ.Checked)

{

centerXOZ.X -= dkx;

this.pnlXOZ.Invalidate();

}

if (rdbtnYOZ.Checked)

{

centerYOZ.X -= dkx;

this.pnlYOZ.Invalidate();

}

}

//сдвиг по оси Y вниз

private void btnYdown_Click(object sender, EventArgs e)

{

if (rdbtnXOY.Checked)

{

centerXOY.Y -= dky;

this.pnlXOY.Invalidate();

}

if (rdbtnXOZ.Checked)

{

centerXOZ.Y -= dky;

this.pnlXOZ.Invalidate();

}

if (rdbtnYOZ.Checked)

{

centerYOZ.Y -= dky;

this.pnlYOZ.Invalidate();

}

}

//сдвиг по оси Y вверх

private void btnYup_Click(object sender, EventArgs e)

{

if (rdbtnXOY.Checked)

{

centerXOY.Y += dky;

this.pnlXOY.Invalidate();

}

if (rdbtnXOZ.Checked)

{

centerXOZ.Y += dky;

this.pnlXOZ.Invalidate();

}

if (rdbtnYOZ.Checked)

{

centerYOZ.Y += dky;

this.pnlYOZ.Invalidate();

}

}

private void pnlXOY_Paint(object sender, PaintEventArgs e)

{

Pen OXY = new Pen(Color.Blue, 2); //перо оси XOY

Pen setka = new Pen(Color.Gray, 1); //перо масштабной сетки

Pen figur = new Pen(Color.Red, 3); //перо для рисования фигуры

Pen figur1 = new Pen(Color.Blue, 3);

Graphics g = e.Graphics;

Font txt = new Font("Arial", 14, FontStyle.Bold);

int count = 0;

float cx, cy;  //текущие точки плоскости XOY

g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality;

g.PixelOffsetMode = System.Drawing.Drawing2D.PixelOffsetMode.HighQuality;

g.FillRectangle(Brushes.White, 0, 0, pnlXOY.Size.Width, pnlXOY.Size.Height);

sizeX = int.Parse(mashtab_ox.Value.ToString());

sizeY = int.Parse(mashtab_oy.Value.ToString());

stepX = 1 / sizeX;

stepY = 1 / sizeY;

//рисование масштабной сетки по x

for (XY.X = centerXOY.X, count = 0; XY.X < pnlXOY.Size.Width; XY.X += sizeX, count--)

{

g.DrawLine(setka, XY.X, 0, XY.X, pnlXOY.Size.Height);

g.DrawString(count.ToString(), txt, Brushes.Black, XY.X - txt.Size, centerXOY.Y);

}

for (XY.X = centerXOY.X, count = 0; XY.X > 0; XY.X -= sizeX, count++)

{

g.DrawLine(setka, XY.X, 0, XY.X, pnlXOY.Size.Height);

if (count != 0)

g.DrawString(count.ToString(), txt, Brushes.Black, XY.X - 1.5f * txt.Size, centerXOY.Y);

}

//по y

for (XY.Y = centerXOY.Y, count = 0; XY.Y > 0; XY.Y -= sizeY, count--)

{

g.DrawLine(setka, 0, XY.Y, pnlXOY.Size.Width, XY.Y);

if (count != 0)

g.DrawString(count.ToString(), txt, Brushes.Black, centerXOY.X - 1.5f*txt.Size, XY.Y);

}

for (XY.Y = centerXOY.Y, count = 0; XY.Y < pnlXOY.Size.Height; XY.Y += sizeY, count++)

{

g.DrawLine(setka, 0, XY.Y, pnlXOY.Size.Width, XY.Y);

if (count != 0)

g.DrawString(count.ToString(), txt, Brushes.Black, centerXOY.X - txt.Size, XY.Y);

}

//рисование координатных осей

g.DrawLine(OXY, 0, centerXOY.Y, pnlXOY.Size.Width, centerXOY.Y);