summaryrefslogtreecommitdiffstats
path: root/chrome/browser/printing/page_setup.cc
diff options
context:
space:
mode:
authorinitial.commit <initial.commit@0039d316-1c4b-4281-b951-d872f2087c98>2008-07-26 23:55:29 +0000
committerinitial.commit <initial.commit@0039d316-1c4b-4281-b951-d872f2087c98>2008-07-26 23:55:29 +0000
commit09911bf300f1a419907a9412154760efd0b7abc3 (patch)
treef131325fb4e2ad12c6d3504ab75b16dd92facfed /chrome/browser/printing/page_setup.cc
parent586acc5fe142f498261f52c66862fa417c3d52d2 (diff)
downloadchromium_src-09911bf300f1a419907a9412154760efd0b7abc3.zip
chromium_src-09911bf300f1a419907a9412154760efd0b7abc3.tar.gz
chromium_src-09911bf300f1a419907a9412154760efd0b7abc3.tar.bz2
Add chrome to the repository.
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@15 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/printing/page_setup.cc')
-rw-r--r--chrome/browser/printing/page_setup.cc151
1 files changed, 151 insertions, 0 deletions
diff --git a/chrome/browser/printing/page_setup.cc b/chrome/browser/printing/page_setup.cc
new file mode 100644
index 0000000..6d6c42a
--- /dev/null
+++ b/chrome/browser/printing/page_setup.cc
@@ -0,0 +1,151 @@
+// Copyright 2008, Google Inc.
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the names of its
+// contributors may be used to endorse or promote products derived from
+// this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+#include "chrome/browser/printing/page_setup.h"
+
+#include "base/logging.h"
+
+namespace printing {
+
+PageMargins::PageMargins()
+ : header(0),
+ footer(0),
+ left(0),
+ right(0),
+ top(0),
+ bottom(0) {
+}
+
+void PageMargins::Clear() {
+ header = 0;
+ footer = 0;
+ left = 0;
+ right = 0;
+ top = 0;
+ bottom = 0;
+}
+
+bool PageMargins::Equals(const PageMargins& rhs) const {
+ return header == rhs.header &&
+ footer == rhs.footer &&
+ left == rhs.left &&
+ top == rhs.top &&
+ right == rhs.right &&
+ bottom == rhs.bottom;
+}
+
+PageSetup::PageSetup() : text_height_(0) {
+}
+
+void PageSetup::Clear() {
+ physical_size_.SetSize(0, 0);
+ printable_area_.SetRect(0, 0, 0, 0);
+ overlay_area_.SetRect(0, 0, 0, 0);
+ content_area_.SetRect(0, 0, 0, 0);
+ effective_margins_.Clear();
+ text_height_ = 0;
+}
+
+bool PageSetup::Equals(const PageSetup& rhs) const {
+ return physical_size_ == rhs.physical_size_ &&
+ printable_area_ == rhs.printable_area_ &&
+ overlay_area_ == rhs.overlay_area_ &&
+ content_area_ == rhs.content_area_ &&
+ effective_margins_.Equals(rhs.effective_margins_) &&
+ requested_margins_.Equals(rhs.requested_margins_) &&
+ text_height_ == rhs.text_height_;
+}
+
+void PageSetup::Init(const gfx::Size& physical_size,
+ const gfx::Rect& printable_area,
+ int text_height) {
+ DCHECK_LE(printable_area.right(), physical_size.width());
+ // I've seen this assert triggers on Canon GP160PF PCL 5e.
+ // 28092 vs. 27940 @ 600 dpi = ~.25 inch.
+ DCHECK_LE(printable_area.bottom(), physical_size.height());
+ DCHECK_GE(printable_area.x(), 0);
+ DCHECK_GE(printable_area.y(), 0);
+ DCHECK_GE(text_height, 0);
+ physical_size_ = physical_size;
+ printable_area_ = printable_area;
+ text_height_ = text_height;
+
+ // Calculate the effective margins. The tricky part.
+ effective_margins_.header = std::max(requested_margins_.header,
+ printable_area_.y());
+ effective_margins_.footer = std::max(requested_margins_.footer,
+ physical_size.height() -
+ printable_area_.bottom());
+ effective_margins_.left = std::max(requested_margins_.left,
+ printable_area_.x());
+ effective_margins_.top = std::max(std::max(requested_margins_.top,
+ printable_area_.y()),
+ effective_margins_.header + text_height);
+ effective_margins_.right = std::max(requested_margins_.right,
+ physical_size.width() -
+ printable_area_.right());
+ effective_margins_.bottom = std::max(std::max(requested_margins_.bottom,
+ physical_size.height() -
+ printable_area_.bottom()),
+ effective_margins_.footer + text_height);
+
+ // Calculate the overlay area. If the margins are excessive, the overlay_area
+ // size will be (0, 0).
+ overlay_area_.set_x(effective_margins_.left);
+ overlay_area_.set_y(effective_margins_.header);
+ overlay_area_.set_width(std::max(0,
+ physical_size.width() -
+ effective_margins_.right -
+ overlay_area_.x()));
+ overlay_area_.set_height(std::max(0,
+ physical_size.height() -
+ effective_margins_.footer -
+ overlay_area_.y()));
+
+ // Calculate the content area. If the margins are excessive, the content_area
+ // size will be (0, 0).
+ content_area_.set_x(effective_margins_.left);
+ content_area_.set_y(effective_margins_.top);
+ content_area_.set_width(std::max(0,
+ physical_size.width() -
+ effective_margins_.right -
+ content_area_.x()));
+ content_area_.set_height(std::max(0,
+ physical_size.height() -
+ effective_margins_.bottom -
+ content_area_.y()));
+}
+
+void PageSetup::SetRequestedMargins(const PageMargins& requested_margins) {
+ requested_margins_ = requested_margins;
+ if (physical_size_.width() && physical_size_.height())
+ Init(physical_size_, printable_area_, text_height_);
+}
+
+} // namespace printing