Drawing a border on an image

2019-04-10 19:12发布

I'm currently trying to make a mask generator to generate polygons for images. Here's my code.

Bitmap bmp = new Bitmap(file);
int w = bmp.Width;
int h = bmp.Height;
List<Point> vertices = new List<Point>();

for (int y=0; y<h; y++)
{
    bool rowbegin = false;
    for (int x=0; x<w; x++)
    {
        Color c = bmp.GetPixel(x, y);
        if (!rowbegin)
        {
            // Check for a non alpha color
            if (c.A != Color.Transparent.A)
            {
                rowbegin = true;
                // This is the first point in the row
                vertices.Add(new Point(x, y));
            }
        } else {
            // Check for an alpha color
            if (c.A == Color.Transparent.A)
            {
                // The previous pixel is the last point in the row
                vertices.Add(new Point(x-1, y));
                rowbegin = false;
            }
        }
    }
}

// Convert to an array of points
Point[] polygon = vertices.ToArray();

Graphics g = Graphics.FromImage(bmp);

g.DrawPolygon(Pens.LawnGreen, polygon);
g.Dispose();

But I'm getting wrong output.

enter image description here

The required.

enter image description here

What I want is also the gaps between the characters to be empty. Also why DrawPolygon is filling it?

Thanks.

标签: c# drawing
1条回答
Deceive 欺骗
2楼-- · 2019-04-10 20:10

Do you trying something like this:i hope my code help you:

enter image description here

  public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();

        }

        private void Form1_Load(object sender, EventArgs e)
        {
            Bitmap bmp = new Bitmap(@"C:\Users\Ali\Desktop\1.png");
            int w = bmp.Width;
            int h = bmp.Height;
            Lst_Data lastpointcolor = new Lst_Data() ;
            for (int y = 0; y < h; y++)
            {
                for (int x = 0; x < w; x++)
                {
                    Color c = bmp.GetPixel(x, y);
                    if (c.A != Color.Transparent.A)
                    {
                        if (lastpointcolor.color.A == Color.Transparent.A)
                        {
                            bmp.SetPixel(lastpointcolor.point.X, lastpointcolor.point.Y, Color.Red);
                        }
                    }
                    lastpointcolor = new Lst_Data() { point = new Point(x, y), color = bmp.GetPixel(x, y) };
                }
            }

            for (int y = h-1; y > 0; y--)
            {
                for (int x = w-1; x > 0; x--)
                {
                    Color c = bmp.GetPixel(x, y);
                    if (c.A != Color.Transparent.A)
                    {
                        if (lastpointcolor.color.A == Color.Transparent.A)
                        {
                            bmp.SetPixel(lastpointcolor.point.X, lastpointcolor.point.Y, Color.Red);
                        }
                    }
                    lastpointcolor = new Lst_Data() { point = new Point(x, y), color = bmp.GetPixel(x, y) };
                }
            }
            pictureBox1.Image = bmp;
        }
    }
    public struct Lst_Data
    {
        public Point point;
        public Color color;
    }
}

Edited:

And Another idea i have for you:D

Make a mask for original image with the same size and do this:

    Bitmap orginal = new Bitmap(@"C:\Users\Ali\Desktop\orginal.png");
    Bitmap mask = new Bitmap(@"C:\Users\Ali\Desktop\mask.png");
    for (int i = 0; i < orginal.Width; i++)
    {
        for (int j = 0; j < orginal.Height; j++)
        {
            if (orginal.GetPixel(i, j).A == Color.Transparent.A)
            {
                mask.SetPixel(i, j, Color.Transparent);
            }
        } 
    }
    Bitmap bitmap = new Bitmap(mask, mask.Height, mask.Height);
    using (Graphics g = Graphics.FromImage(bitmap))
    {
        g.DrawImage(mask, 0, 0);
        g.DrawImage(orginal,0,0);
    }
    pictureBox1.Image = bitmap;

Result:

enter image description here

enter image description here

查看更多
登录 后发表回答