|
EAN13 holds only a 13-digit article number: you are thinking about EAN13+2 and EAN13+5 which are extensions to the basic EAN13 spec - and there isn't anything which says what those additional digits must be: they do not have to be weight or price.
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
|
|
|
|
|
We are using EAN13 that contains only 13 digits and in this 13 digits is price or weight with article number without any extra 2 or 5 digits - it's always 13 digits EAN13 code.
|
|
|
|
|
If that's true - and I don't believe it for a moment - then what you are doing is probably very dangerous in commercial terms. The only values allowed in an EAN-13 standard bar code is a single Article Number, which is assigned to a comp-any for a specific product by the appropriate national body (for a charge) in order that it is unique world-wide. All POS systems read the barcode, extract the AN, and use it for a DB lookup to identify the exact product scanned, and from that same DB get the weight, price, dimensions, manufacturer and such like. None of that is directly stored in the BC - it's all DB stored and linked to the AN received from the BC.
If you are storing weights and prices in the AN, then unless you have purchased a pretty huge block of ANs from your issuing authority, then you are probably issuing items with EAN13 BCs which identify them to the real world as toothpaste, or rubber gloves, or fresh chicken portions ...
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
|
|
|
|
|
This's not our standard code - we have to print it because some of our clients need such EAN13 code - this code is printed on label only if our customer wants. Clients send us specification of codes which they want from us. Clients' POS systems reads it correctly.
This is just a market need.
|
|
|
|
|
Then you will have to read your clients specification, because what you are doing is non-standard so we cannot tell you what parts of the code you need to extract, or how they are encoded...
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
|
|
|
|
|
I only wanted to show you that EAN13 can also contain weight or price because you wrote that EAN13 contains only article number. My question was about decoding string not only from EAN13 which are the easiest to do - most of all I need help with EAN128, Code128 where are many possibilities and AI.
|
|
|
|
|
If it's a "custom code", then it's not EAN13 or anything else "published"; so stop referring to it in that way. Call it what it is: a custom (barcode) encoding.
|
|
|
|
|
Dzilupl wrote: USB reads a barcode and sends string od chars (mostly numbers) That's how they work. They decode the barcode and send you the string of characters. From there, you just do whatever you need to do, for example, lookup the value in a database.
There are only 10 types of people in the world, those who understand binary and those who don't.
|
|
|
|
|
A barcode reader is just like a keyboard. After is scans the code it decodes it and sends you like it was an input string... To try and interpret the scanned image by yourself will be a total waste of time, and a sure way to errors...
If you have to handle specific barcode formats, buy a scanner can handle it...
Skipper: We'll fix it.
Alex: Fix it? How you gonna fix this?
Skipper: Grit, spit and a whole lotta duct tape.
|
|
|
|
|
I don't want to decode image. My application send me as you wrote string readed from barcode image. I want to decode this string into separate information connected with barcodes AI's. I get string like 019123456789012331030605781516120510161128001 and I want to get it into PLU 01 - 1234567890123 then weight 3103 06000 (60,578kg), best before 15 161205 (05.12.2016) and LOT 10 161128001.
|
|
|
|
|
A barcode holds continuous information and the meaning of that is decided by those who wrote it. There is no global/common decoding of such string, but only in connection to the product printed on...
I worked with barcodes where there was a separator (like comma) and also with codes without any separation...
Simply there is no on-size-for-all solution when decoding the meaning of a barcode...
Skipper: We'll fix it.
Alex: Fix it? How you gonna fix this?
Skipper: Grit, spit and a whole lotta duct tape.
|
|
|
|
|
Actually, there is, for UCC/EAN128 barcodes - I no longer have a copy, but there is an official spec which describes the barcode, which is broken into a large range of possible fields, including specific ones for price, weight, batch, production dates, serial numbers, and pretty much anything else you might want in a item identifier. The spec weighs around three Kg IIRC ... I've probably still got the Z80 assembler code to generate them from the constituent parts somewhere, but it could take months to find it!
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
|
|
|
|
|
I know GS1-128 and also EPC and I worked with barcodes (as part of a project for warehouse management) - those are standards made for the paper mostly. The problem with GS1 is that it holds a lot of copyrights that makes it almost impossible to use their ideas because of the fear of infringement...
So - one may write a method to interpret GS1 or EPC, but in most cases it will not work. As today, almost every manufacturer has his own system to create codes (and barcodes from them) and it may change even for the same manufacturer from product to product...
Skipper: We'll fix it.
Alex: Fix it? How you gonna fix this?
Skipper: Grit, spit and a whole lotta duct tape.
|
|
|
|
|
You're not going to find a library for this.
It comes down to simple string manipulation. You get a code from the scanner and you have to break it down into the parts you need. There's nothing magical about this.
|
|
|
|
|
You are saying you get a string of digits (nothing to do with barcodes) and you know the structure of the information in the string. So what exactly is your problem in separating and decoding these fields?
|
|
|
|
|
I don't know exactly what is the structure of the information because it can be different. For example 1 EAN128 code can contains only article number and batch, another one can contains article number with weight and batch, another can contains article with number of pieces and production date etc. There are many possibilities. AI tells what information this string contains and what I need is good algorithm that search for all possible AI and decode string into separate information. I don't want to miss any possibility.
|
|
|
|
|
|
I know all that you send me but like I said - i don't want to miss something and I asked if anyone is using some ready solutions (also paid) that can do this decoding for me.
|
|
|
|
|
If there is already a library in existence for this then Google is the place to look. If Google does not find one then you need to write your own. It's not exactly a difficult problem.
|
|
|
|
|
What you're talking about is using a standardized format to non-standard uses. There isn't going to be a library for this!
If you're going to use an EAN128 code that can have differing fields from one scan to another, you MUST have another field that tells your code which field format is being used for that code. For example:
Layout ProductCode Weight
1 394857394587 12.46
Layout ProductCode Count
2 294579834759 12
Layout ProductCode DateCode Count
3 324875938457 1623 12
You're going to have to write your own library for this, both to generate the barcodes and to read them.
|
|
|
|
|
If you don't know what the layout is supposed to be or how to parse this (using .Substring, for example), how can you confirm that any "library" will do what you want?
|
|
|
|
|
Hello, about ten years ago, I developed my first and only one client app for a barcode scanner, it was a psion workabout scanner, i can't remember how, but I remember that PSION provided an API that allowed me to register my app into the scanner hardware and get the scanning codes as EVENTS instead of use keyboard emulation, the event arguments were a structure containing lot of metadata about the barcode, such as "barcode kind" geometries and so on, the event arguments also provided a raw byte array of scanning data, which I used to parse a bunch of GS-1 logistic labels.
All the above just to say that maybe the hardware manufacturer could provide you the API you need to communicate with their hardware device / driver.
Good luck
|
|
|
|
|
Assuming the program appears to open the form repeated in many places in the program through the following code:
[CODE]
if (agreed conditions the open form 1)
{
Form1 frm = new Form1();
frm.Show();
}
[/CODE]
instead of checking conditions in outside open Form1 form and the opening of Form1 appears many places in the program you want to put conditions inside Form1 it will be difficult to implement, there are certain you know this how ?
|
|
|
|
|
You could, I suppose, implement a static method in the Form class that would check if the correct conditions exist, and then create (and display) the form, but you would still have to call this method from any place where the form should be displayed.
If the conditions could be encapsulated in an event, perhaps it would be possible to create an event handler that would create the form. It all depends on what you are trying to achieve. However, unless the conditions for showing the form are identical in all locations, I see no advantage to using either of these techniques.
If you have an important point to make, don't try to be subtle or clever. Use a pile driver. Hit the point once. Then come back and hit it again. Then hit it a third time - a tremendous whack.
--Winston Churchill
|
|
|
|
|
Add a static method to the Form which checks the conditions, and if they are all fine, creates the instance and displays it. Then all you have to do is call the static method.
So if your condition was for example "number of elements greater than five"
public static Form1 CreateIfNeeded(int count)
{
if (count > 5)
{
Form1 f = new Form1();
f.Show();
return f;
}
return null;
} And call it:
Form1 f = Form1.CreateIfNeeded(MyList.Count);
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
|
|
|
|