Drawing and Saving an Image












0















I am in the process of developing an app that will be later integrated with another app I developed some time ago.



Basically, this app will generate an image file of X and Y dimensions with a grid printed on it, of which the user also specifies it's interval.



I've done this form so far, but I am having difficulty deciding what the best way to generate an actual image with the proper dimensions and grid spacing should be.



I don't want to save the image that is displayed on the form because it is only a representation and could very well be extremely dissimilar from the final product.



So I guess my question is, what do you think the best way is to generate a black and white image when I click "save"?



Also, I have no need to see the image being saved, I just want to generate and save it behind the scenes.



Here is the "draw" button click event



private void btnDraw_Click(object sender, EventArgs e)
{
this.Width = 560;
using (g = pb.CreateGraphics())
{
g.Clear(Color.White);

PaintCanvass canvass = new PaintCanvass();
canvass.Width = Convert.ToDouble(tbWidth.Text);
canvass.Height = Convert.ToDouble(tbHeight.Text);
canvass.Resolution = Convert.ToInt32(cbResolution.Text.Substring(0,3));
canvass.UOM = cbUOM.Text;
canvass.Interval = Convert.ToInt32(tbInterval.Text);

Pen pencil = new Pen(Color.Black, 2);
int hpfact = Convert.ToInt32((double)pb.Height / (double)canvass.horizontalLinesQuantity);
int hp = hpfact;

for (int i = 0; i < canvass.horizontalLinesQuantity-1; i++)
{
g.DrawLine(pencil, new Point(0, hp), new Point(pb.Width, hp));
hp = hp + hpfact;
}
int vpfact = Convert.ToInt32((double)pb.Width / (double)canvass.verticalLinesQuantity);
int vp = vpfact;
for (int i = 0; i < canvass.verticalLinesQuantity-1; i++)
{
g.DrawLine(pencil, new Point(vp, 0), new Point(vp, pb.Height));
vp = vp + vpfact;
}
canvass = null;


And here is my PaintCanvass class which seems to just be ending up as a container for properties for now



   class PaintCanvass
{
public double Width { get; set; }
public double Height { get; set; }
public string UOM { get; set; }
public int Resolution { get; set; }
public int Interval { get; set; } = 50;
public int hdots
{
get
{
if (this.UOM == "mm")
{
return Convert.ToInt32(Width * 0.03937008F * Resolution);
}
else
{
return Convert.ToInt32(Width * Resolution);
};
}
}
public int vdots
{
get
{
// Set the quantity of lines
if (this.UOM == "mm")
{
return Convert.ToInt32(Height * 0.03937008F * Resolution);
}
else
{
return Convert.ToInt32(Height * Resolution);
};
}
}
public int horizontalLinesQuantity
{
get
{
return vdots / this.Interval;
}
}
public int verticalLinesQuantity
{
get
{
return hdots / this.Interval;
}
}
}


Current Form Sample



Edit: as suggested I went with the bitmap method.



private void btnSave_Click(object sender, EventArgs e)
{
SetupCanvass();
using (Bitmap bmp = new Bitmap(canvass.hdots, canvass.vdots))
{
using (Graphics g = Graphics.FromImage(bmp))
{
using (SolidBrush brush = new SolidBrush(Color.FromArgb(255, 255, 255)))
{
g.FillRectangle(brush, 0, 0, canvass.hdots, canvass.vdots);
}
int hp = canvass.Interval;
for (int i = 0; i < canvass.horizontalLinesQuantity - 1; i++)
{
g.DrawLine(pencil, new Point(0, hp), new Point(canvass.hdots, hp));
hp = hp + canvass.Interval;
}
int vp = canvass.Interval;
for (int i = 0; i < canvass.verticalLinesQuantity - 1; i++)
{
g.DrawLine(pencil, new Point(vp, 0), new Point(vp, canvass.vdots));
vp = vp + canvass.Interval;
}
}
bmp.Save(Path.Combine(Path.GetTempPath(), "labelGrid.png")); //Save image somwhere on disk
}
}









share|improve this question




















  • 1





    Why not generate a new Bitmap, display that one in the picturebox and then save the bitmap instance when clicking on the button? No need to draw on the canvas

    – Icepickle
    Nov 22 '18 at 8:42











  • @Icepickle As stated in the post "I don't want to save the image that is displayed on the form because it is only a representation and could very well be extremely dissimilar from the final product."

    – Jaberwocky
    Nov 22 '18 at 8:48











  • Sure, I didn't suggest that either, I suggested you generate a bitmap instead of drawing to the canvas and save that bitmap, but as you till now display a preview, you could theoretically also show the bitmap in the picturebox (optionally)

    – Icepickle
    Nov 22 '18 at 8:49











  • @Icepickle Why don't you post some small example of what you mean as an answer? I am assuming you're saying to create a bitmap using the PictureBox.Image property?

    – Jaberwocky
    Nov 22 '18 at 8:51











  • No just use new Bitmap( width, height, PixelFormat) and create graphics from that instance

    – Icepickle
    Nov 22 '18 at 8:55
















0















I am in the process of developing an app that will be later integrated with another app I developed some time ago.



Basically, this app will generate an image file of X and Y dimensions with a grid printed on it, of which the user also specifies it's interval.



I've done this form so far, but I am having difficulty deciding what the best way to generate an actual image with the proper dimensions and grid spacing should be.



I don't want to save the image that is displayed on the form because it is only a representation and could very well be extremely dissimilar from the final product.



So I guess my question is, what do you think the best way is to generate a black and white image when I click "save"?



Also, I have no need to see the image being saved, I just want to generate and save it behind the scenes.



Here is the "draw" button click event



private void btnDraw_Click(object sender, EventArgs e)
{
this.Width = 560;
using (g = pb.CreateGraphics())
{
g.Clear(Color.White);

PaintCanvass canvass = new PaintCanvass();
canvass.Width = Convert.ToDouble(tbWidth.Text);
canvass.Height = Convert.ToDouble(tbHeight.Text);
canvass.Resolution = Convert.ToInt32(cbResolution.Text.Substring(0,3));
canvass.UOM = cbUOM.Text;
canvass.Interval = Convert.ToInt32(tbInterval.Text);

Pen pencil = new Pen(Color.Black, 2);
int hpfact = Convert.ToInt32((double)pb.Height / (double)canvass.horizontalLinesQuantity);
int hp = hpfact;

for (int i = 0; i < canvass.horizontalLinesQuantity-1; i++)
{
g.DrawLine(pencil, new Point(0, hp), new Point(pb.Width, hp));
hp = hp + hpfact;
}
int vpfact = Convert.ToInt32((double)pb.Width / (double)canvass.verticalLinesQuantity);
int vp = vpfact;
for (int i = 0; i < canvass.verticalLinesQuantity-1; i++)
{
g.DrawLine(pencil, new Point(vp, 0), new Point(vp, pb.Height));
vp = vp + vpfact;
}
canvass = null;


And here is my PaintCanvass class which seems to just be ending up as a container for properties for now



   class PaintCanvass
{
public double Width { get; set; }
public double Height { get; set; }
public string UOM { get; set; }
public int Resolution { get; set; }
public int Interval { get; set; } = 50;
public int hdots
{
get
{
if (this.UOM == "mm")
{
return Convert.ToInt32(Width * 0.03937008F * Resolution);
}
else
{
return Convert.ToInt32(Width * Resolution);
};
}
}
public int vdots
{
get
{
// Set the quantity of lines
if (this.UOM == "mm")
{
return Convert.ToInt32(Height * 0.03937008F * Resolution);
}
else
{
return Convert.ToInt32(Height * Resolution);
};
}
}
public int horizontalLinesQuantity
{
get
{
return vdots / this.Interval;
}
}
public int verticalLinesQuantity
{
get
{
return hdots / this.Interval;
}
}
}


Current Form Sample



Edit: as suggested I went with the bitmap method.



private void btnSave_Click(object sender, EventArgs e)
{
SetupCanvass();
using (Bitmap bmp = new Bitmap(canvass.hdots, canvass.vdots))
{
using (Graphics g = Graphics.FromImage(bmp))
{
using (SolidBrush brush = new SolidBrush(Color.FromArgb(255, 255, 255)))
{
g.FillRectangle(brush, 0, 0, canvass.hdots, canvass.vdots);
}
int hp = canvass.Interval;
for (int i = 0; i < canvass.horizontalLinesQuantity - 1; i++)
{
g.DrawLine(pencil, new Point(0, hp), new Point(canvass.hdots, hp));
hp = hp + canvass.Interval;
}
int vp = canvass.Interval;
for (int i = 0; i < canvass.verticalLinesQuantity - 1; i++)
{
g.DrawLine(pencil, new Point(vp, 0), new Point(vp, canvass.vdots));
vp = vp + canvass.Interval;
}
}
bmp.Save(Path.Combine(Path.GetTempPath(), "labelGrid.png")); //Save image somwhere on disk
}
}









share|improve this question




















  • 1





    Why not generate a new Bitmap, display that one in the picturebox and then save the bitmap instance when clicking on the button? No need to draw on the canvas

    – Icepickle
    Nov 22 '18 at 8:42











  • @Icepickle As stated in the post "I don't want to save the image that is displayed on the form because it is only a representation and could very well be extremely dissimilar from the final product."

    – Jaberwocky
    Nov 22 '18 at 8:48











  • Sure, I didn't suggest that either, I suggested you generate a bitmap instead of drawing to the canvas and save that bitmap, but as you till now display a preview, you could theoretically also show the bitmap in the picturebox (optionally)

    – Icepickle
    Nov 22 '18 at 8:49











  • @Icepickle Why don't you post some small example of what you mean as an answer? I am assuming you're saying to create a bitmap using the PictureBox.Image property?

    – Jaberwocky
    Nov 22 '18 at 8:51











  • No just use new Bitmap( width, height, PixelFormat) and create graphics from that instance

    – Icepickle
    Nov 22 '18 at 8:55














0












0








0








I am in the process of developing an app that will be later integrated with another app I developed some time ago.



Basically, this app will generate an image file of X and Y dimensions with a grid printed on it, of which the user also specifies it's interval.



I've done this form so far, but I am having difficulty deciding what the best way to generate an actual image with the proper dimensions and grid spacing should be.



I don't want to save the image that is displayed on the form because it is only a representation and could very well be extremely dissimilar from the final product.



So I guess my question is, what do you think the best way is to generate a black and white image when I click "save"?



Also, I have no need to see the image being saved, I just want to generate and save it behind the scenes.



Here is the "draw" button click event



private void btnDraw_Click(object sender, EventArgs e)
{
this.Width = 560;
using (g = pb.CreateGraphics())
{
g.Clear(Color.White);

PaintCanvass canvass = new PaintCanvass();
canvass.Width = Convert.ToDouble(tbWidth.Text);
canvass.Height = Convert.ToDouble(tbHeight.Text);
canvass.Resolution = Convert.ToInt32(cbResolution.Text.Substring(0,3));
canvass.UOM = cbUOM.Text;
canvass.Interval = Convert.ToInt32(tbInterval.Text);

Pen pencil = new Pen(Color.Black, 2);
int hpfact = Convert.ToInt32((double)pb.Height / (double)canvass.horizontalLinesQuantity);
int hp = hpfact;

for (int i = 0; i < canvass.horizontalLinesQuantity-1; i++)
{
g.DrawLine(pencil, new Point(0, hp), new Point(pb.Width, hp));
hp = hp + hpfact;
}
int vpfact = Convert.ToInt32((double)pb.Width / (double)canvass.verticalLinesQuantity);
int vp = vpfact;
for (int i = 0; i < canvass.verticalLinesQuantity-1; i++)
{
g.DrawLine(pencil, new Point(vp, 0), new Point(vp, pb.Height));
vp = vp + vpfact;
}
canvass = null;


And here is my PaintCanvass class which seems to just be ending up as a container for properties for now



   class PaintCanvass
{
public double Width { get; set; }
public double Height { get; set; }
public string UOM { get; set; }
public int Resolution { get; set; }
public int Interval { get; set; } = 50;
public int hdots
{
get
{
if (this.UOM == "mm")
{
return Convert.ToInt32(Width * 0.03937008F * Resolution);
}
else
{
return Convert.ToInt32(Width * Resolution);
};
}
}
public int vdots
{
get
{
// Set the quantity of lines
if (this.UOM == "mm")
{
return Convert.ToInt32(Height * 0.03937008F * Resolution);
}
else
{
return Convert.ToInt32(Height * Resolution);
};
}
}
public int horizontalLinesQuantity
{
get
{
return vdots / this.Interval;
}
}
public int verticalLinesQuantity
{
get
{
return hdots / this.Interval;
}
}
}


Current Form Sample



Edit: as suggested I went with the bitmap method.



private void btnSave_Click(object sender, EventArgs e)
{
SetupCanvass();
using (Bitmap bmp = new Bitmap(canvass.hdots, canvass.vdots))
{
using (Graphics g = Graphics.FromImage(bmp))
{
using (SolidBrush brush = new SolidBrush(Color.FromArgb(255, 255, 255)))
{
g.FillRectangle(brush, 0, 0, canvass.hdots, canvass.vdots);
}
int hp = canvass.Interval;
for (int i = 0; i < canvass.horizontalLinesQuantity - 1; i++)
{
g.DrawLine(pencil, new Point(0, hp), new Point(canvass.hdots, hp));
hp = hp + canvass.Interval;
}
int vp = canvass.Interval;
for (int i = 0; i < canvass.verticalLinesQuantity - 1; i++)
{
g.DrawLine(pencil, new Point(vp, 0), new Point(vp, canvass.vdots));
vp = vp + canvass.Interval;
}
}
bmp.Save(Path.Combine(Path.GetTempPath(), "labelGrid.png")); //Save image somwhere on disk
}
}









share|improve this question
















I am in the process of developing an app that will be later integrated with another app I developed some time ago.



Basically, this app will generate an image file of X and Y dimensions with a grid printed on it, of which the user also specifies it's interval.



I've done this form so far, but I am having difficulty deciding what the best way to generate an actual image with the proper dimensions and grid spacing should be.



I don't want to save the image that is displayed on the form because it is only a representation and could very well be extremely dissimilar from the final product.



So I guess my question is, what do you think the best way is to generate a black and white image when I click "save"?



Also, I have no need to see the image being saved, I just want to generate and save it behind the scenes.



Here is the "draw" button click event



private void btnDraw_Click(object sender, EventArgs e)
{
this.Width = 560;
using (g = pb.CreateGraphics())
{
g.Clear(Color.White);

PaintCanvass canvass = new PaintCanvass();
canvass.Width = Convert.ToDouble(tbWidth.Text);
canvass.Height = Convert.ToDouble(tbHeight.Text);
canvass.Resolution = Convert.ToInt32(cbResolution.Text.Substring(0,3));
canvass.UOM = cbUOM.Text;
canvass.Interval = Convert.ToInt32(tbInterval.Text);

Pen pencil = new Pen(Color.Black, 2);
int hpfact = Convert.ToInt32((double)pb.Height / (double)canvass.horizontalLinesQuantity);
int hp = hpfact;

for (int i = 0; i < canvass.horizontalLinesQuantity-1; i++)
{
g.DrawLine(pencil, new Point(0, hp), new Point(pb.Width, hp));
hp = hp + hpfact;
}
int vpfact = Convert.ToInt32((double)pb.Width / (double)canvass.verticalLinesQuantity);
int vp = vpfact;
for (int i = 0; i < canvass.verticalLinesQuantity-1; i++)
{
g.DrawLine(pencil, new Point(vp, 0), new Point(vp, pb.Height));
vp = vp + vpfact;
}
canvass = null;


And here is my PaintCanvass class which seems to just be ending up as a container for properties for now



   class PaintCanvass
{
public double Width { get; set; }
public double Height { get; set; }
public string UOM { get; set; }
public int Resolution { get; set; }
public int Interval { get; set; } = 50;
public int hdots
{
get
{
if (this.UOM == "mm")
{
return Convert.ToInt32(Width * 0.03937008F * Resolution);
}
else
{
return Convert.ToInt32(Width * Resolution);
};
}
}
public int vdots
{
get
{
// Set the quantity of lines
if (this.UOM == "mm")
{
return Convert.ToInt32(Height * 0.03937008F * Resolution);
}
else
{
return Convert.ToInt32(Height * Resolution);
};
}
}
public int horizontalLinesQuantity
{
get
{
return vdots / this.Interval;
}
}
public int verticalLinesQuantity
{
get
{
return hdots / this.Interval;
}
}
}


Current Form Sample



Edit: as suggested I went with the bitmap method.



private void btnSave_Click(object sender, EventArgs e)
{
SetupCanvass();
using (Bitmap bmp = new Bitmap(canvass.hdots, canvass.vdots))
{
using (Graphics g = Graphics.FromImage(bmp))
{
using (SolidBrush brush = new SolidBrush(Color.FromArgb(255, 255, 255)))
{
g.FillRectangle(brush, 0, 0, canvass.hdots, canvass.vdots);
}
int hp = canvass.Interval;
for (int i = 0; i < canvass.horizontalLinesQuantity - 1; i++)
{
g.DrawLine(pencil, new Point(0, hp), new Point(canvass.hdots, hp));
hp = hp + canvass.Interval;
}
int vp = canvass.Interval;
for (int i = 0; i < canvass.verticalLinesQuantity - 1; i++)
{
g.DrawLine(pencil, new Point(vp, 0), new Point(vp, canvass.vdots));
vp = vp + canvass.Interval;
}
}
bmp.Save(Path.Combine(Path.GetTempPath(), "labelGrid.png")); //Save image somwhere on disk
}
}






c#






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 22 '18 at 11:11







Jaberwocky

















asked Nov 22 '18 at 8:29









JaberwockyJaberwocky

6961316




6961316








  • 1





    Why not generate a new Bitmap, display that one in the picturebox and then save the bitmap instance when clicking on the button? No need to draw on the canvas

    – Icepickle
    Nov 22 '18 at 8:42











  • @Icepickle As stated in the post "I don't want to save the image that is displayed on the form because it is only a representation and could very well be extremely dissimilar from the final product."

    – Jaberwocky
    Nov 22 '18 at 8:48











  • Sure, I didn't suggest that either, I suggested you generate a bitmap instead of drawing to the canvas and save that bitmap, but as you till now display a preview, you could theoretically also show the bitmap in the picturebox (optionally)

    – Icepickle
    Nov 22 '18 at 8:49











  • @Icepickle Why don't you post some small example of what you mean as an answer? I am assuming you're saying to create a bitmap using the PictureBox.Image property?

    – Jaberwocky
    Nov 22 '18 at 8:51











  • No just use new Bitmap( width, height, PixelFormat) and create graphics from that instance

    – Icepickle
    Nov 22 '18 at 8:55














  • 1





    Why not generate a new Bitmap, display that one in the picturebox and then save the bitmap instance when clicking on the button? No need to draw on the canvas

    – Icepickle
    Nov 22 '18 at 8:42











  • @Icepickle As stated in the post "I don't want to save the image that is displayed on the form because it is only a representation and could very well be extremely dissimilar from the final product."

    – Jaberwocky
    Nov 22 '18 at 8:48











  • Sure, I didn't suggest that either, I suggested you generate a bitmap instead of drawing to the canvas and save that bitmap, but as you till now display a preview, you could theoretically also show the bitmap in the picturebox (optionally)

    – Icepickle
    Nov 22 '18 at 8:49











  • @Icepickle Why don't you post some small example of what you mean as an answer? I am assuming you're saying to create a bitmap using the PictureBox.Image property?

    – Jaberwocky
    Nov 22 '18 at 8:51











  • No just use new Bitmap( width, height, PixelFormat) and create graphics from that instance

    – Icepickle
    Nov 22 '18 at 8:55








1




1





Why not generate a new Bitmap, display that one in the picturebox and then save the bitmap instance when clicking on the button? No need to draw on the canvas

– Icepickle
Nov 22 '18 at 8:42





Why not generate a new Bitmap, display that one in the picturebox and then save the bitmap instance when clicking on the button? No need to draw on the canvas

– Icepickle
Nov 22 '18 at 8:42













@Icepickle As stated in the post "I don't want to save the image that is displayed on the form because it is only a representation and could very well be extremely dissimilar from the final product."

– Jaberwocky
Nov 22 '18 at 8:48





@Icepickle As stated in the post "I don't want to save the image that is displayed on the form because it is only a representation and could very well be extremely dissimilar from the final product."

– Jaberwocky
Nov 22 '18 at 8:48













Sure, I didn't suggest that either, I suggested you generate a bitmap instead of drawing to the canvas and save that bitmap, but as you till now display a preview, you could theoretically also show the bitmap in the picturebox (optionally)

– Icepickle
Nov 22 '18 at 8:49





Sure, I didn't suggest that either, I suggested you generate a bitmap instead of drawing to the canvas and save that bitmap, but as you till now display a preview, you could theoretically also show the bitmap in the picturebox (optionally)

– Icepickle
Nov 22 '18 at 8:49













@Icepickle Why don't you post some small example of what you mean as an answer? I am assuming you're saying to create a bitmap using the PictureBox.Image property?

– Jaberwocky
Nov 22 '18 at 8:51





@Icepickle Why don't you post some small example of what you mean as an answer? I am assuming you're saying to create a bitmap using the PictureBox.Image property?

– Jaberwocky
Nov 22 '18 at 8:51













No just use new Bitmap( width, height, PixelFormat) and create graphics from that instance

– Icepickle
Nov 22 '18 at 8:55





No just use new Bitmap( width, height, PixelFormat) and create graphics from that instance

– Icepickle
Nov 22 '18 at 8:55












1 Answer
1






active

oldest

votes


















0














If you want to save an image without displaying a preview, just do something like this:



using (Bitmap bmp = new Bitmap(500, 500))
{
using (Graphics g = Graphics.FromImage(bmp))
{
//Draw your stuff directly onto the bitmap here
}
bmp.Save("C:\image.bmp"); //Save image somwhere on disk
}





share|improve this answer



















  • 2





    Basically correct but a) better not save to the root and b) better pick a more reasonable format like jpg or png. Also I would recommend setting the dpiX/Y of the bitmap.

    – TaW
    Nov 22 '18 at 9:45








  • 1





    Well, I mean this code snippet was only meant as an example...

    – cmos
    Nov 22 '18 at 9:50











Your Answer






StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53426699%2fdrawing-and-saving-an-image%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes









0














If you want to save an image without displaying a preview, just do something like this:



using (Bitmap bmp = new Bitmap(500, 500))
{
using (Graphics g = Graphics.FromImage(bmp))
{
//Draw your stuff directly onto the bitmap here
}
bmp.Save("C:\image.bmp"); //Save image somwhere on disk
}





share|improve this answer



















  • 2





    Basically correct but a) better not save to the root and b) better pick a more reasonable format like jpg or png. Also I would recommend setting the dpiX/Y of the bitmap.

    – TaW
    Nov 22 '18 at 9:45








  • 1





    Well, I mean this code snippet was only meant as an example...

    – cmos
    Nov 22 '18 at 9:50
















0














If you want to save an image without displaying a preview, just do something like this:



using (Bitmap bmp = new Bitmap(500, 500))
{
using (Graphics g = Graphics.FromImage(bmp))
{
//Draw your stuff directly onto the bitmap here
}
bmp.Save("C:\image.bmp"); //Save image somwhere on disk
}





share|improve this answer



















  • 2





    Basically correct but a) better not save to the root and b) better pick a more reasonable format like jpg or png. Also I would recommend setting the dpiX/Y of the bitmap.

    – TaW
    Nov 22 '18 at 9:45








  • 1





    Well, I mean this code snippet was only meant as an example...

    – cmos
    Nov 22 '18 at 9:50














0












0








0







If you want to save an image without displaying a preview, just do something like this:



using (Bitmap bmp = new Bitmap(500, 500))
{
using (Graphics g = Graphics.FromImage(bmp))
{
//Draw your stuff directly onto the bitmap here
}
bmp.Save("C:\image.bmp"); //Save image somwhere on disk
}





share|improve this answer













If you want to save an image without displaying a preview, just do something like this:



using (Bitmap bmp = new Bitmap(500, 500))
{
using (Graphics g = Graphics.FromImage(bmp))
{
//Draw your stuff directly onto the bitmap here
}
bmp.Save("C:\image.bmp"); //Save image somwhere on disk
}






share|improve this answer












share|improve this answer



share|improve this answer










answered Nov 22 '18 at 8:56









cmoscmos

262412




262412








  • 2





    Basically correct but a) better not save to the root and b) better pick a more reasonable format like jpg or png. Also I would recommend setting the dpiX/Y of the bitmap.

    – TaW
    Nov 22 '18 at 9:45








  • 1





    Well, I mean this code snippet was only meant as an example...

    – cmos
    Nov 22 '18 at 9:50














  • 2





    Basically correct but a) better not save to the root and b) better pick a more reasonable format like jpg or png. Also I would recommend setting the dpiX/Y of the bitmap.

    – TaW
    Nov 22 '18 at 9:45








  • 1





    Well, I mean this code snippet was only meant as an example...

    – cmos
    Nov 22 '18 at 9:50








2




2





Basically correct but a) better not save to the root and b) better pick a more reasonable format like jpg or png. Also I would recommend setting the dpiX/Y of the bitmap.

– TaW
Nov 22 '18 at 9:45







Basically correct but a) better not save to the root and b) better pick a more reasonable format like jpg or png. Also I would recommend setting the dpiX/Y of the bitmap.

– TaW
Nov 22 '18 at 9:45






1




1





Well, I mean this code snippet was only meant as an example...

– cmos
Nov 22 '18 at 9:50





Well, I mean this code snippet was only meant as an example...

– cmos
Nov 22 '18 at 9:50




















draft saved

draft discarded




















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53426699%2fdrawing-and-saving-an-image%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

MongoDB - Not Authorized To Execute Command

in spring boot 2.1 many test slices are not allowed anymore due to multiple @BootstrapWith

How to fix TextFormField cause rebuild widget in Flutter