AF
HomeTagSubmit NotesAsk AnythingLoginSubscribe Us
AF
1. Feel Free to ask and submit anything on Anyforum.in and get satisfactory answer
2. Registration is not compulsory, you can directly login via google or facebook
3. Our Experts are looking for yours ?.



ASPNet-C-Sharp: How to integrate barcode scanner in ASP and C-sharp?

I have an Point of sell application(POS) developed in ASP.net and C#.Net 4.0 and now I want to integrate barcode scanner. How can I do? What is code for that? Give answer in steps. Thanks in advance.

ASPNet x 2
C-Sharp x 3
Posted On : 2015-02-12 14:17:12.0
profile Amol Ghadage - anyforum.in Amol Ghadage
2900
up-rate
4
down-rate

Answers


There are many representation available for barcode and barcode reader for respective representation. But they may be expensive and dealing with an unlimited number of clients licences. For example we need an alphanumeric barcode representation and the preferred barcode representation was Code39.

In order to expose this service to the maximum of clients while delivering a standardized solution, I thought of writing a web service that would generate the barcode dynamically and return it streamlined as an image.


The Barcode Generation:
-------------------------------------------------------------
Instead of writing a code39 barcode generator that mimics the algorithm for that barcode representation, my idea was to use one of the freely available barcode fonts to produce the barcode (http://www.squaregear.net/fonts/free3of9.shtml).

So my approach was simple:

1. Load the Barcode Font
2. Create an image object
3. Draw a string into that image using a code39 barcode font
4. Return that image serialized.


Using the Code39 Font:
------------------------------------------------------
The way to use a font in windows is simple, all you have to do is install it (by copying it to the c:\WINDOWS\Fonts - under XP) and just use it.


Unfortunately, the ASP.NET graphic context does not allow you to use any font (free3of9.ttf for example) because .NET GDI only uses/enumerates OpenType fonts. So what you have to do is create a temporary font object.

This method is very straighforward, as you can see in the code sample below:


// Create a private font collection
objectPrivateFontCollection pfc=new PrivateFontCollection();

// Load in the temporary barcode font
pfc.AddFontFile("c:\\barcodefont\\free3of9.ttf");

// Select the font family to use
FontFamily family=new FontFamily("Free 3 of 9",pfc);

// Create the font object with size 30
Font c39Font=new Font(family,30);


With this easy way, you get a font object mapped to the barcode font so that you can create the barcode.

Creating the Barcode Image Container:
-------------------------------------------------------------------------
The image creation is very simple. .NET classes allow you to generate images on the fly. So, in order to create a image large enough to accommodate the barcode, first you need to determine the size that will be occupied by the code string drawing, using the barcode font.


You can do it using the MeasureString method:
-------------------------------------------------------------------------------------
// Create a temporary bitmap...
Bitmap tmpBitmap = new Bitmap(1,1,PixelFormat.Format32bppArgb);
objGraphics = Graphics.FromImage(tmpBitmap);
// measure the barcode size...
SizeF barCodeSize=objGraphics.MeasureString(barCodeString,c39Font);

The returned type barCodeSize has the width, and the height that will be occupied by the code string drawing.

Draw the Barcode:
---------------------------------------------
So now we need to draw the barcode. We will use the code39 barcode font object instantiated earlier.

Assuming the the barcode variable holds the barcode string, the required code is:
// Draw the barcode
objGraphics.DrawString(barCode, Code39Font, new solidBrush(Color.Black),0,0);

Please note that usualy the code39 barcodes are represented concatenating the char (*) at the beginning and end of the barcode string?meaning that code 123456 has to be written as *123456*. But I will leave that to your experience.

Serialize/Deserialize the Image:
--------------------------------------------------------------------
In order to return the image from the web service method, you now have to serialize the image, meaning that your web method has to return an array of bytes.

This way, you have to create a stream from the bitmap image, and return it as an array of bytes. Once again, the .NET framework makes it easy for us do perform that task:

// Create stream....
MemoryStream ms = new MemoryStream();

// save the image to the stream
objBitmap.Save(ms ,ImageFormat.Png);

//return an array of bytes....
return ms.GetBuffer();

On the other end (the client side) when you are consuming the web service, you need to be able to deserialize the array of bytes back to the image:

Byte[] imgBarcode;

// Call the webservice to create the barcode...

// Create a stream....
MemoryStream memStream = new MemoryStream(imgBarcode);

// Recreate the image from the stream<BR>Bitmap bmp=new Bitmap(memStream);
A final note about the sample code attached?

After creating the barcode web app that will be your webservice, you need to configure the web.config file in order to specify where your barcode font is located. Search for the following section and make your changes accordingly.

<appSettings>
<add key="BarCodeFontFile" value="c:\temp\font\FREE3OF9.TTF" />
<add key="BarCodeFontFamily" value="Free 3 of 9" />
</appSettings>

Posted On : 2015-02-26 23:55:21
Satisfied : 1 Yes  0 No
profile Garima Gupta - anyforum.in Garima Gupta
596129560202
Reply This Thread
up-rate
4
down-rate



Post Answer
Please Login First to Post Answer: Login login with facebook - anyforum.in