/*
* Copyright 2013 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.Internal
{
///
/// Meta-data container for QR Code decoding. Instances of this class may be used to convey information back to the
/// decoding caller. Callers are expected to process this.
///
public sealed class QRCodeDecoderMetaData
{
private readonly bool mirrored;
///
/// Initializes a new instance of the class.
///
/// if set to true [mirrored].
public QRCodeDecoderMetaData(bool mirrored)
{
this.mirrored = mirrored;
}
///
/// true if the QR Code was mirrored.
///
public bool IsMirrored
{
get { return mirrored; }
}
///
/// Apply the result points' order correction due to mirroring.
///
/// Array of points to apply mirror correction to.
public void applyMirroredCorrection(ResultPoint[] points)
{
if (!mirrored || points == null || points.Length < 3)
{
return;
}
ResultPoint bottomLeft = points[0];
points[0] = points[2];
points[2] = bottomLeft;
// No need to 'fix' top-left and alignment pattern.
}
}
}