单军华
2017-07-12 20d1260d26b028897f3c0935c12fc35aa37b2e93
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
/*
 * Copyright 2012 ZXing authors
 *
 * 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.
 */
 
@class ZXBinaryBitmap, ZXDecodeHints, ZXResult;
 
/**
 * Implementations of this interface can decode an image of a barcode in some format into
 * the String it encodes. For example, ZXQRCodeReader can
 * decode a QR code. The decoder may optionally receive hints from the caller which may help
 * it decode more quickly or accurately.
 *
 * See ZXMultiFormatReader, which attempts to determine what barcode
 * format is present within the image as well, and then decodes it accordingly.
 */
@protocol ZXReader <NSObject>
 
/**
 * Locates and decodes a barcode in some format within an image.
 *
 * @param image image of barcode to decode
 * @return String which the barcode encodes or nil if
 *  the barcode cannot be located or decoded for any reason
 */
- (ZXResult *)decode:(ZXBinaryBitmap *)image error:(NSError **)error;
 
/**
 * Locates and decodes a barcode in some format within an image. This method also accepts
 * hints, each possibly associated to some data, which may help the implementation decode.
 *
 * @param image image of barcode to decode
 * @param hints passed as a {@link java.util.Map} from {@link com.google.zxing.DecodeHintType}
 * to arbitrary data. The
 * meaning of the data depends upon the hint type. The implementation may or may not do
 * anything with these hints.
 * @return String which the barcode encodes or nil if
 *  the barcode cannot be located or decoded for any reason
 */
- (ZXResult *)decode:(ZXBinaryBitmap *)image hints:(ZXDecodeHints *)hints error:(NSError **)error;
 
/**
 * Resets any internal state the implementation has after a decode, to prepare it
 * for reuse.
 */
- (void)reset;
 
@end