Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Общие вопросы по .NET и C# > Нужно нарисовать пятиугольники


Автор: Уттара 23.4.2010, 14:51
Здравствуйте!
Нужно нарисовать 6 пятиугольников, 1 в центре, и 5 вокруг облепляют центральный, примерно так (набросок):

http://saveimg.ru/show-image.php?id=d1ddbaf0107d21cfe38e3ecc9d8446b4

Сам код для рисования многоугольника я написал:
Код

        public void Draw(Graphics g, int len, int R, Point Center, Point Pos)
        {
            const double Rad = Math.PI / 180;
            int rd = 0;
            int i = 0;
            Point[] p = new Point[] { };
            double a = 0.0, ad = 0.0;
            a = 0;
            len = 5;
            ad = 360 / len;
            Array.Resize(ref p, len);
            for (i = 0; i < len; i++)
            {
                rd = R;
                p[i].X = (int)(Math.Cos(a * Rad) * rd) + Center.X;
                p[i].Y = (int)(Math.Sin(a * Rad) * rd) + Center.Y;
                a += ad;
            }
            g.DrawPolygon(new Pen(Brushes.Black), p);
        }


А вызов, чтобы нарисовать пятиугольник так:
Код

Draw(e.Graphics, 5, 89, new Point(pictureBox1.Width/2, pictureBox1.Height/2), new Point(0, 0));


Вот  только не знаю как их расположить рядом, как на картинке)))

Автор: Heinzz 23.4.2010, 18:15
Код

 public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            this.Paint += new PaintEventHandler(Form1_Paint);
        }

        void Form1_Paint(object sender, PaintEventArgs e)
        {
            Point[] points = Draw(e.Graphics, 5, 50, new Point(this.Width / 2, this.Height / 2), 0);
            double angle = 180/5;
            foreach (Point p in points)
            {
                Draw(e.Graphics, 5, 50, new Point(p.X, p.Y), angle);
                angle += 360 / 5;
            }
        }


        public Point[] Draw(Graphics g, int len, int R, Point Center, double a)
        {
            Point[] centers = new Point[len];
            const double Rad = Math.PI / 180;
            Point[] p = new Point[len];
            double ad = 360 / len;
            for (int i = 0; i < len; i++)
            {
                p[i].X = (int)(Math.Cos(a * Rad) * R) + Center.X;
                p[i].Y = (int)(Math.Sin(a * Rad) * R) + Center.Y;
                double x = Center.X + R * (Math.Cos(a * Rad) + Math.Cos((a-ad) * Rad));
                double y = Center.X + R * (Math.Sin(a * Rad) + Math.Sin((a-ad) * Rad));
                centers[i] = new Point((int)x,(int)y);
                a += ad;
            }
            g.DrawPolygon(new Pen(Brushes.Black), p);
            return centers;
        }
    }

Автор: Уттара 23.4.2010, 22:19
Heinzz, спасибо, то что надо! smile 

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)