1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- <?php
- /*
- * Copyright 2007 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.
- */
- namespace Zxing\Qrcode\Decoder;
- /**
- * <p>See ISO 18004:2006, 6.5.1. This enum encapsulates the four error correction levels
- * defined by the QR code standard.</p>
- *
- * @author Sean Owen
- */
- class ErrorCorrectionLevel {
- private static $FOR_BITS;
- private $bits;
- private $ordinal;
- function __construct($bits,$ordinal=0) {
- $this->bits = $bits;
- $this->ordinal = $ordinal;
- }
- public static function Init(){
- self::$FOR_BITS = array(
- new ErrorCorrectionLevel(0x00,1), //M
- new ErrorCorrectionLevel(0x01,0), //L
- new ErrorCorrectionLevel(0x02,3), //H
- new ErrorCorrectionLevel(0x03,2), //Q
- );
- }
- /** L = ~7% correction */
- // self::$L = new ErrorCorrectionLevel(0x01);
- /** M = ~15% correction */
- //self::$M = new ErrorCorrectionLevel(0x00);
- /** Q = ~25% correction */
- //self::$Q = new ErrorCorrectionLevel(0x03);
- /** H = ~30% correction */
- //self::$H = new ErrorCorrectionLevel(0x02);
- public function getBits() {
- return $this->bits;
- }
- public function toString() {
- return $this->bits;
- }
- public function getOrdinal() {
- return $this->ordinal;
- }
- /**
- * @param bits int containing the two bits encoding a QR Code's error correction level
- * @return ErrorCorrectionLevel representing the encoded error correction level
- */
- public static function forBits($bits) {
- if ($bits < 0 || $bits >= count(self::$FOR_BITS)) {
- throw new InvalidArgumentException();
- }
- $level = self::$FOR_BITS[$bits];
- // $lev = self::$$bit;
- return $level;
- }
- }
- ErrorCorrectionLevel::Init();
|