OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "printing/page_setup.h" | 5 #include "printing/page_setup.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 | 8 |
9 #include "base/logging.h" | 9 #include "base/logging.h" |
10 | 10 |
11 namespace printing { | 11 namespace printing { |
12 | 12 |
13 PageMargins::PageMargins() | 13 PageMargins::PageMargins() |
14 : header(0), | 14 : header(0), |
15 footer(0), | 15 footer(0), |
16 left(0), | 16 left(0), |
17 right(0), | 17 right(0), |
18 top(0), | 18 top(0), |
19 bottom(0) { | 19 bottom(0) { |
20 } | 20 } |
21 | 21 |
22 void PageMargins::RotatePageMarginsAndUpdateCurrentValue( | |
23 const PageMargins& margins) { | |
24 header = margins.header; | |
25 footer = margins.footer; | |
26 top = margins.right; | |
27 left = margins.top; | |
28 bottom = margins.left; | |
29 right = margins.bottom; | |
30 } | |
31 | |
22 void PageMargins::Clear() { | 32 void PageMargins::Clear() { |
23 header = 0; | 33 header = 0; |
24 footer = 0; | 34 footer = 0; |
25 left = 0; | 35 left = 0; |
26 right = 0; | 36 right = 0; |
27 top = 0; | 37 top = 0; |
28 bottom = 0; | 38 bottom = 0; |
29 } | 39 } |
30 | 40 |
31 bool PageMargins::Equals(const PageMargins& rhs) const { | 41 bool PageMargins::Equals(const PageMargins& rhs) const { |
32 return header == rhs.header && | 42 return header == rhs.header && |
33 footer == rhs.footer && | 43 footer == rhs.footer && |
34 left == rhs.left && | 44 left == rhs.left && |
35 top == rhs.top && | 45 top == rhs.top && |
36 right == rhs.right && | 46 right == rhs.right && |
37 bottom == rhs.bottom; | 47 bottom == rhs.bottom; |
38 } | 48 } |
39 | 49 |
40 PageSetup::PageSetup() { | 50 PageSetup::PageSetup() : forced_margins_(false) { |
41 Clear(); | 51 Clear(); |
42 } | 52 } |
43 | 53 |
44 PageSetup::~PageSetup() {} | 54 PageSetup::~PageSetup() {} |
45 | 55 |
46 void PageSetup::Clear() { | 56 void PageSetup::Clear() { |
47 physical_size_.SetSize(0, 0); | 57 physical_size_.SetSize(0, 0); |
48 printable_area_.SetRect(0, 0, 0, 0); | 58 printable_area_.SetRect(0, 0, 0, 0); |
49 overlay_area_.SetRect(0, 0, 0, 0); | 59 overlay_area_.SetRect(0, 0, 0, 0); |
50 content_area_.SetRect(0, 0, 0, 0); | 60 content_area_.SetRect(0, 0, 0, 0); |
51 effective_margins_.Clear(); | 61 effective_margins_.Clear(); |
52 text_height_ = 0; | 62 text_height_ = 0; |
vandebo (ex-Chrome)
2011/11/03 17:26:35
clear should probably reset forced_margins_
kmadhusu
2011/11/03 20:46:54
oops. Fixed.
| |
53 } | 63 } |
54 | 64 |
55 bool PageSetup::Equals(const PageSetup& rhs) const { | 65 bool PageSetup::Equals(const PageSetup& rhs) const { |
56 return physical_size_ == rhs.physical_size_ && | 66 return physical_size_ == rhs.physical_size_ && |
57 printable_area_ == rhs.printable_area_ && | 67 printable_area_ == rhs.printable_area_ && |
58 overlay_area_ == rhs.overlay_area_ && | 68 overlay_area_ == rhs.overlay_area_ && |
59 content_area_ == rhs.content_area_ && | 69 content_area_ == rhs.content_area_ && |
60 effective_margins_.Equals(rhs.effective_margins_) && | 70 effective_margins_.Equals(rhs.effective_margins_) && |
61 requested_margins_.Equals(rhs.requested_margins_) && | 71 requested_margins_.Equals(rhs.requested_margins_) && |
62 text_height_ == rhs.text_height_; | 72 text_height_ == rhs.text_height_; |
63 } | 73 } |
64 | 74 |
65 void PageSetup::Init(const gfx::Size& physical_size, | 75 void PageSetup::Init(const gfx::Size& physical_size, |
66 const gfx::Rect& printable_area, | 76 const gfx::Rect& printable_area, |
67 int text_height) { | 77 int text_height) { |
68 DCHECK_LE(printable_area.right(), physical_size.width()); | 78 DCHECK_LE(printable_area.right(), physical_size.width()); |
69 // I've seen this assert triggers on Canon GP160PF PCL 5e and HP LaserJet 5. | 79 // I've seen this assert triggers on Canon GP160PF PCL 5e and HP LaserJet 5. |
70 // Since we don't know the dpi here, just disable the check. | 80 // Since we don't know the dpi here, just disable the check. |
71 // DCHECK_LE(printable_area.bottom(), physical_size.height()); | 81 // DCHECK_LE(printable_area.bottom(), physical_size.height()); |
72 DCHECK_GE(printable_area.x(), 0); | 82 DCHECK_GE(printable_area.x(), 0); |
73 DCHECK_GE(printable_area.y(), 0); | 83 DCHECK_GE(printable_area.y(), 0); |
74 DCHECK_GE(text_height, 0); | 84 DCHECK_GE(text_height, 0); |
75 physical_size_ = physical_size; | 85 physical_size_ = physical_size; |
76 printable_area_ = printable_area; | 86 printable_area_ = printable_area; |
77 text_height_ = text_height; | 87 text_height_ = text_height; |
78 | 88 |
79 CalculateSizesWithinRect(printable_area_, text_height_); | 89 CalculateSizesWithinRect(printable_area_, text_height_); |
vandebo (ex-Chrome)
2011/11/03 17:26:35
This should call SetRequestedMarginsANdUpdateValue
kmadhusu
2011/11/03 20:46:54
Done.
| |
80 } | 90 } |
81 | 91 |
82 void PageSetup::SetRequestedMargins(const PageMargins& requested_margins) { | 92 void PageSetup::SetRequestedMargins(const PageMargins& requested_margins) { |
83 requested_margins_ = requested_margins; | 93 forced_margins_ = false; |
84 if (printable_area_.width() && printable_area_.height()) | 94 SetRequestedMarginsAndUpdateValues(requested_margins); |
85 CalculateSizesWithinRect(printable_area_, text_height_); | |
86 } | 95 } |
87 | 96 |
88 void PageSetup::ForceRequestedMargins(const PageMargins& requested_margins) { | 97 void PageSetup::ForceRequestedMargins(const PageMargins& requested_margins) { |
89 requested_margins_ = requested_margins; | 98 forced_margins_ = true; |
90 if (physical_size_.width() && physical_size_.height()) | 99 SetRequestedMarginsAndUpdateValues(requested_margins); |
91 CalculateSizesWithinRect(gfx::Rect(physical_size_), 0); | |
92 } | 100 } |
93 | 101 |
94 void PageSetup::FlipOrientation() { | 102 void PageSetup::FlipOrientation() { |
95 if (physical_size_.width() && physical_size_.height()) { | 103 if (physical_size_.width() && physical_size_.height()) { |
96 gfx::Size new_size(physical_size_.height(), physical_size_.width()); | 104 gfx::Size new_size(physical_size_.height(), physical_size_.width()); |
97 int new_y = physical_size_.width() - | 105 int new_y = physical_size_.width() - |
98 (printable_area_.width() + printable_area_.x()); | 106 (printable_area_.width() + printable_area_.x()); |
99 gfx::Rect new_printable_area(printable_area_.y(), | 107 gfx::Rect new_printable_area(printable_area_.y(), |
100 new_y, | 108 new_y, |
101 printable_area_.height(), | 109 printable_area_.height(), |
102 printable_area_.width()); | 110 printable_area_.width()); |
103 Init(new_size, new_printable_area, text_height_); | 111 Init(new_size, new_printable_area, text_height_); |
112 PageMargins new_margins; | |
113 new_margins.RotatePageMarginsAndUpdateCurrentValue(requested_margins_); | |
114 SetRequestedMarginsAndUpdateValues(new_margins); | |
104 } | 115 } |
105 } | 116 } |
106 | 117 |
118 void PageSetup::SetRequestedMarginsAndUpdateValues( | |
119 const PageMargins& requested_margins) { | |
120 requested_margins_ = requested_margins; | |
121 if (forced_margins_) { | |
122 if (physical_size_.width() && physical_size_.height()) | |
vandebo (ex-Chrome)
2011/11/03 17:26:35
Pull this 'if' up one scope so you don't have to r
kmadhusu
2011/11/03 20:46:54
if (physical_size_....) {
if (forced_margins_)
| |
123 CalculateSizesWithinRect(gfx::Rect(physical_size_), 0); | |
124 } else { | |
125 if (printable_area_.width() && printable_area_.height()) | |
126 CalculateSizesWithinRect(printable_area_, text_height_); | |
127 } | |
128 } | |
129 | |
107 void PageSetup::CalculateSizesWithinRect(const gfx::Rect& bounds, | 130 void PageSetup::CalculateSizesWithinRect(const gfx::Rect& bounds, |
108 int text_height) { | 131 int text_height) { |
109 // Calculate the effective margins. The tricky part. | 132 // Calculate the effective margins. The tricky part. |
110 effective_margins_.header = std::max(requested_margins_.header, | 133 effective_margins_.header = std::max(requested_margins_.header, |
111 bounds.y()); | 134 bounds.y()); |
112 effective_margins_.footer = std::max(requested_margins_.footer, | 135 effective_margins_.footer = std::max(requested_margins_.footer, |
113 physical_size_.height() - | 136 physical_size_.height() - |
114 bounds.bottom()); | 137 bounds.bottom()); |
115 effective_margins_.left = std::max(requested_margins_.left, | 138 effective_margins_.left = std::max(requested_margins_.left, |
116 bounds.x()); | 139 bounds.x()); |
(...skipping 13 matching lines...) Expand all Loading... | |
130 overlay_area_.set_x(effective_margins_.left); | 153 overlay_area_.set_x(effective_margins_.left); |
131 overlay_area_.set_y(effective_margins_.header); | 154 overlay_area_.set_y(effective_margins_.header); |
132 overlay_area_.set_width(std::max(0, | 155 overlay_area_.set_width(std::max(0, |
133 physical_size_.width() - | 156 physical_size_.width() - |
134 effective_margins_.right - | 157 effective_margins_.right - |
135 overlay_area_.x())); | 158 overlay_area_.x())); |
136 overlay_area_.set_height(std::max(0, | 159 overlay_area_.set_height(std::max(0, |
137 physical_size_.height() - | 160 physical_size_.height() - |
138 effective_margins_.footer - | 161 effective_margins_.footer - |
139 overlay_area_.y())); | 162 overlay_area_.y())); |
140 | |
141 // Calculate the content area. If the margins are excessive, the content_area | 163 // Calculate the content area. If the margins are excessive, the content_area |
142 // size will be (0, 0). | 164 // size will be (0, 0). |
143 content_area_.set_x(effective_margins_.left); | 165 content_area_.set_x(effective_margins_.left); |
144 content_area_.set_y(effective_margins_.top); | 166 content_area_.set_y(effective_margins_.top); |
145 content_area_.set_width(std::max(0, | 167 content_area_.set_width(std::max(0, |
146 physical_size_.width() - | 168 physical_size_.width() - |
147 effective_margins_.right - | 169 effective_margins_.right - |
148 content_area_.x())); | 170 content_area_.x())); |
149 content_area_.set_height(std::max(0, | 171 content_area_.set_height(std::max(0, |
150 physical_size_.height() - | 172 physical_size_.height() - |
151 effective_margins_.bottom - | 173 effective_margins_.bottom - |
152 content_area_.y())); | 174 content_area_.y())); |
153 } | 175 } |
154 | 176 |
155 } // namespace printing | 177 } // namespace printing |
OLD | NEW |