internal static Version decodeVersionInformation(int versionBits) { int bestDifference = System.Int32.MaxValue; int bestVersion = 0; for (int i = 0; i < VERSION_DECODE_INFO.Length; i++) { int targetVersion = VERSION_DECODE_INFO[i]; // Do the version info bits match exactly? done. if (targetVersion == versionBits) { return(getVersionForNumber(i + 7)); } // Otherwise see if this is the closest to a real version info bit string // we have seen so far int bitsDifference = FormatInformation.numBitsDiffering(versionBits, targetVersion); if (bitsDifference < bestDifference) { bestVersion = i + 7; bestDifference = bitsDifference; } } // We can tolerate up to 3 bits of error since no two version info codewords will // differ in less than 4 bits. if (bestDifference <= 3) { return(getVersionForNumber(bestVersion)); } // If we didn't find a close enough match, fail return(null); }
public override bool Equals(System.Object o) { if (!(o is FormatInformation)) { return(false); } FormatInformation other = (FormatInformation)o; return(this.errorCorrectionLevel == other.errorCorrectionLevel && this.dataMask == other.dataMask); }
/// <param name="maskedFormatInfo">format info indicator, with mask still applied /// </param> /// <returns> information about the format it specifies, or <code>null</code> /// if doesn't seem to match any known pattern /// </returns> internal static FormatInformation decodeFormatInformation(int maskedFormatInfo) { FormatInformation formatInfo = doDecodeFormatInformation(maskedFormatInfo); if (formatInfo != null) { return(formatInfo); } // Should return null, but, some QR codes apparently // do not mask this info. Try again by actually masking the pattern // first return(doDecodeFormatInformation(maskedFormatInfo ^ FORMAT_INFO_MASK_QR)); }