mirror of
https://github.com/zxing/zxing.git
synced 2025-01-13 04:07:27 -08:00
7854d30103
git-svn-id: https://zxing.googlecode.com/svn/trunk@817 59b500cc-1b3d-0410-9834-0bbf25fbcc57
106 lines
3.6 KiB
C#
Executable file
106 lines
3.6 KiB
C#
Executable file
/*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
using System;
|
|
using System.Collections;
|
|
|
|
namespace com.google.zxing
|
|
{
|
|
|
|
/// <summary> The general exception class throw when something goes wrong during decoding of a barcode.
|
|
/// This includes, but is not limited to, failing checksums / error correction algorithms, being
|
|
/// unable to locate finder timing patterns, and so on.
|
|
///
|
|
/// </summary>
|
|
/// <author> srowen@google.com (Sean Owen)
|
|
/// </author>
|
|
//[Serializable]
|
|
public sealed class Result
|
|
{
|
|
private String text;
|
|
private sbyte[] rawBytes;
|
|
private ResultPoint[] resultPoints;
|
|
private BarcodeFormat format;
|
|
private Hashtable resultMetadata;
|
|
|
|
public Result(String text,
|
|
sbyte[] rawBytes,
|
|
ResultPoint[] resultPoints,
|
|
BarcodeFormat format) {
|
|
if (text == null && rawBytes == null) {
|
|
throw new ArgumentException("Text and bytes are null");
|
|
}
|
|
this.text = text;
|
|
this.rawBytes = rawBytes;
|
|
this.resultPoints = resultPoints;
|
|
this.format = format;
|
|
this.resultMetadata = null;
|
|
}
|
|
|
|
/**
|
|
* @return raw text encoded by the barcode, if applicable, otherwise <code>null</code>
|
|
*/
|
|
public String getText() {
|
|
return text;
|
|
}
|
|
|
|
/**
|
|
* @return raw bytes encoded by the barcode, if applicable, otherwise <code>null</code>
|
|
*/
|
|
public sbyte[] getRawBytes() {
|
|
return rawBytes;
|
|
}
|
|
|
|
/**
|
|
* @return points related to the barcode in the image. These are typically points
|
|
* identifying finder patterns or the corners of the barcode. The exact meaning is
|
|
* specific to the type of barcode that was decoded.
|
|
*/
|
|
public ResultPoint[] getResultPoints() {
|
|
return resultPoints;
|
|
}
|
|
|
|
/**
|
|
* @return {@link BarcodeFormat} representing the format of the barcode that was recognized and decoded
|
|
*/
|
|
public BarcodeFormat getBarcodeFormat() {
|
|
return format;
|
|
}
|
|
|
|
/**
|
|
* @return {@link Hashtable} mapping {@link ResultMetadataType} keys to values. May be <code>null</code>.
|
|
* This contains optional metadata about what was detected about the barcode, like orientation.
|
|
*/
|
|
public Hashtable getResultMetadata() {
|
|
return resultMetadata;
|
|
}
|
|
|
|
public void putMetadata(ResultMetadataType type, Object value) {
|
|
if (resultMetadata == null) {
|
|
resultMetadata = new Hashtable(3);
|
|
}
|
|
resultMetadata.Add(type, value);
|
|
}
|
|
|
|
public String toString() {
|
|
if (text == null) {
|
|
return "[" + rawBytes.Length + " bytes]";
|
|
} else {
|
|
return text;
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
} |