~ubuntu-branches/ubuntu/raring/qtwebkit-source/raring-proposed

« back to all changes in this revision

Viewing changes to Source/WebCore/platform/graphics/ImageOrientation.h

  • Committer: Package Import Robot
  • Author(s): Jonathan Riddell
  • Date: 2013-02-18 14:24:18 UTC
  • Revision ID: package-import@ubuntu.com-20130218142418-eon0jmjg3nj438uy
Tags: upstream-2.3
ImportĀ upstreamĀ versionĀ 2.3

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * Copyright (C) 2010 Google Inc. All rights reserved.
 
3
 *
 
4
 * Redistribution and use in source and binary forms, with or without
 
5
 * modification, are permitted provided that the following conditions
 
6
 * are met:
 
7
 *
 
8
 * 1.  Redistributions of source code must retain the above copyright
 
9
 *     notice, this list of conditions and the following disclaimer.
 
10
 * 2.  Redistributions in binary form must reproduce the above copyright
 
11
 *     notice, this list of conditions and the following disclaimer in the
 
12
 *     documentation and/or other materials provided with the distribution.
 
13
 *
 
14
 * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY
 
15
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 
16
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 
17
 * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY
 
18
 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 
19
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 
20
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 
21
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 
22
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
 
23
 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 
24
 */
 
25
 
 
26
#ifndef ImageOrientation_h
 
27
#define ImageOrientation_h
 
28
 
 
29
namespace WebCore {
 
30
 
 
31
class AffineTransform;
 
32
class FloatSize;
 
33
 
 
34
// This enum intentionally matches the orientation values from the EXIF spec.
 
35
// See JEITA CP-3451, page 18. http://www.exif.org/Exif2-2.PDF
 
36
enum ImageOrientationEnum {
 
37
    // "TopLeft" means that the 0 row starts at the Top, the 0 column starts at the Left.
 
38
    OriginTopLeft = 1, // default
 
39
    OriginTopRight = 2, // mirror along y-axis
 
40
    OriginBottomRight = 3, // 180 degree rotation
 
41
    OriginBottomLeft = 4, // mirror along the x-axis
 
42
    OriginLeftTop = 5, // mirror along x-axis + 270 degree CW rotation
 
43
    OriginRightTop = 6, // 90 degree CW rotation
 
44
    OriginRightBottom = 7, // mirror along x-axis + 90 degree CW rotation
 
45
    OriginLeftBottom = 8, // 270 degree CW rotation
 
46
    // All other values are "reserved" as of EXIF 2.2
 
47
    DefaultImageOrientation = OriginTopLeft,
 
48
};
 
49
 
 
50
enum RespectImageOrientationEnum {
 
51
    DoNotRespectImageOrientation = 0,
 
52
    RespectImageOrientation = 1
 
53
};
 
54
 
 
55
class ImageOrientation {
 
56
public:
 
57
    ImageOrientation(ImageOrientationEnum orientation = DefaultImageOrientation)
 
58
        : m_orientation(orientation)
 
59
    {
 
60
    }
 
61
 
 
62
    bool usesWidthAsHeight() const
 
63
    {
 
64
        // Values 5 through 8 all flip the width/height.
 
65
        return m_orientation >= OriginLeftTop;
 
66
    }
 
67
 
 
68
    // ImageOrientationEnum currently matches EXIF values, however code outside
 
69
    // this function should never assume that.
 
70
    static ImageOrientation fromEXIFValue(int exifValue)
 
71
    {
 
72
        // Values direct from images may be invalid, in which case we use the default.
 
73
        if (exifValue < OriginTopLeft || exifValue > OriginLeftBottom)
 
74
            return DefaultImageOrientation;
 
75
        return static_cast<ImageOrientationEnum>(exifValue);
 
76
    }
 
77
 
 
78
    // This transform can be used for drawing an image according to the orientation.
 
79
    // It should be used in a right-handed coordinate system.
 
80
    AffineTransform transformFromDefault(const FloatSize& drawnSize) const;
 
81
 
 
82
    inline bool operator==(const ImageOrientation& other) const { return other.m_orientation == m_orientation; }
 
83
    inline bool operator!=(const ImageOrientation& other) const { return !(*this == other); }
 
84
 
 
85
private:
 
86
    // FIXME: This only needs to be one byte.
 
87
    ImageOrientationEnum m_orientation;
 
88
};
 
89
 
 
90
} // namespace WebCore
 
91
 
 
92
#endif // ImageOrientation_h