Home | History | Annotate | Download | only in page
      1 /*
      2  * Copyright (C) 2007 Alp Toker <alp (at) atoker.com>
      3  * Copyright (C) 2007 Apple Inc.
      4  *
      5  * This library is free software; you can redistribute it and/or
      6  * modify it under the terms of the GNU Library General Public
      7  * License as published by the Free Software Foundation; either
      8  * version 2 of the License, or (at your option) any later version.
      9  *
     10  * This library is distributed in the hope that it will be useful,
     11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
     12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
     13  * Library General Public License for more details.
     14  *
     15  * You should have received a copy of the GNU Library General Public License
     16  * along with this library; see the file COPYING.LIB.  If not, write to
     17  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
     18  * Boston, MA 02110-1301, USA.
     19  */
     20 
     21 #ifndef PrintContext_h
     22 #define PrintContext_h
     23 
     24 #include "wtf/Forward.h"
     25 #include "wtf/HashMap.h"
     26 #include "wtf/Vector.h"
     27 #include "wtf/text/WTFString.h"
     28 
     29 namespace WebCore {
     30 
     31 class Element;
     32 class Frame;
     33 class FloatRect;
     34 class FloatSize;
     35 class GraphicsContext;
     36 class IntRect;
     37 class Node;
     38 
     39 class PrintContext {
     40 public:
     41     explicit PrintContext(Frame*);
     42     ~PrintContext();
     43 
     44     Frame* frame() const { return m_frame; }
     45 
     46     // Break up a page into rects without relayout.
     47     // FIXME: This means that CSS page breaks won't be on page boundary if the size is different than what was passed to begin(). That's probably not always desirable.
     48     // FIXME: Header and footer height should be applied before layout, not after.
     49     // FIXME: The printRect argument is only used to determine page aspect ratio, it would be better to pass a FloatSize with page dimensions instead.
     50     void computePageRects(const FloatRect& printRect, float headerHeight, float footerHeight, float userScaleFactor, float& outPageHeight, bool allowHorizontalTiling = false);
     51 
     52     // Deprecated. Page size computation is already in this class, clients shouldn't be copying it.
     53     void computePageRectsWithPageSize(const FloatSize& pageSizeInPixels, bool allowHorizontalTiling);
     54 
     55     // These are only valid after page rects are computed.
     56     size_t pageCount() const { return m_pageRects.size(); }
     57     const IntRect& pageRect(size_t pageNumber) const { return m_pageRects[pageNumber]; }
     58     const Vector<IntRect>& pageRects() const { return m_pageRects; }
     59 
     60     float computeAutomaticScaleFactor(const FloatSize& availablePaperSize);
     61 
     62     // Enter print mode, updating layout for new page size.
     63     // This function can be called multiple times to apply new print options without going back to screen mode.
     64     void begin(float width, float height = 0);
     65 
     66     // FIXME: eliminate width argument.
     67     void spoolPage(GraphicsContext& ctx, int pageNumber, float width);
     68 
     69     void spoolRect(GraphicsContext& ctx, const IntRect&);
     70 
     71     // Return to screen mode.
     72     void end();
     73 
     74     // Used by layout tests.
     75     static int pageNumberForElement(Element*, const FloatSize& pageSizeInPixels); // Returns -1 if page isn't found.
     76     static String pageProperty(Frame* frame, const char* propertyName, int pageNumber);
     77     static bool isPageBoxVisible(Frame* frame, int pageNumber);
     78     static String pageSizeAndMarginsInPixels(Frame* frame, int pageNumber, int width, int height, int marginTop, int marginRight, int marginBottom, int marginLeft);
     79     static int numberOfPages(Frame*, const FloatSize& pageSizeInPixels);
     80     // Draw all pages into a graphics context with lines which mean page boundaries.
     81     // The height of the graphics context should be
     82     // (pageSizeInPixels.height() + 1) * number-of-pages - 1
     83     static void spoolAllPagesWithBoundaries(Frame*, GraphicsContext&, const FloatSize& pageSizeInPixels);
     84 
     85 protected:
     86     void outputLinkedDestinations(GraphicsContext&, Node*, const IntRect& pageRect);
     87 
     88     Frame* m_frame;
     89     Vector<IntRect> m_pageRects;
     90 
     91 private:
     92     void computePageRectsWithPageSizeInternal(const FloatSize& pageSizeInPixels, bool allowHorizontalTiling);
     93     void collectLinkedDestinations(Node*);
     94 
     95     // Used to prevent misuses of begin() and end() (e.g., call end without begin).
     96     bool m_isPrinting;
     97 
     98     HashMap<String, Element*> m_linkedDestinations;
     99     bool m_linkedDestinationsValid;
    100 };
    101 
    102 }
    103 
    104 #endif
    105