/* * $Id: PDFPage.java,v 1.21 2003/03/07 08:25:47 jeremias Exp $ * ============================================================================ * The Apache Software License, Version 1.1 * ============================================================================ * * Copyright (C) 1999-2003 The Apache Software Foundation. All rights reserved. * * Redistribution and use in source and binary forms, with or without modifica- * tion, are permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * * 2. 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. * * 3. The end-user documentation included with the redistribution, if any, must * include the following acknowledgment: "This product includes software * developed by the Apache Software Foundation (http://www.apache.org/)." * Alternately, this acknowledgment may appear in the software itself, if * and wherever such third-party acknowledgments normally appear. * * 4. The names "FOP" and "Apache Software Foundation" must not be used to * endorse or promote products derived from this software without prior * written permission. For written permission, please contact * apache@apache.org. * * 5. Products derived from this software may not be called "Apache", nor may * "Apache" appear in their name, without prior written permission of the * Apache Software Foundation. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED 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 * APACHE SOFTWARE FOUNDATION OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLU- * DING, 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. * ============================================================================ * * This software consists of voluntary contributions made by many individuals * on behalf of the Apache Software Foundation and was originally created by * James Tauber . For more information on the Apache * Software Foundation, please see . */ package org.apache.fop.pdf; /** * Class representing a /Page object. *

* There is one of these for every page in a PDF document. The object * specifies the dimensions of the page and references a /Resources * object, a contents stream and the page's parent in the page * hierarchy. */ public class PDFPage extends PDFResourceContext { /** * Holds a reference on the parent PDFPages object. */ private String parentRef; /** * the contents stream */ protected PDFStream contents; /** * the width of the page in points */ protected int pagewidth; /** * the height of the page in points */ protected int pageheight; /** * Duration to display page */ protected int duration = -1; /** * Transition dictionary */ protected TransitionDictionary trDictionary = null; /** * create a /Page object * * @param resources the /Resources object * @param contents the content stream * @param pagewidth the page's width in points * @param pageheight the page's height in points */ public PDFPage(PDFResources resources, PDFStream contents, int pagewidth, int pageheight) { /* generic creation of object */ super(resources); /* set fields using parameters */ this.contents = contents; this.pagewidth = pagewidth; this.pageheight = pageheight; } /** * create a /Page object * * @param resources the /Resources object * @param pagewidth the page's width in points * @param pageheight the page's height in points */ public PDFPage(PDFResources resources, int pagewidth, int pageheight) { /* generic creation of object */ super(resources); /* set fields using parameters */ this.pagewidth = pagewidth; this.pageheight = pageheight; } /** * set this page contents * * @param contents the contents of the page */ public void setContents(PDFStream contents) { this.contents = contents; } /** * set this page's parent * * @param parent the /Pages object that is this page's parent */ public void setParent(PDFPages parent) { this.parentRef = parent.referencePDF(); } /** * Set the transition dictionary and duration. * This sets the duration of the page and the transition * dictionary used when going to the next page. * * @param dur the duration in seconds * @param tr the transition dictionary */ public void setTransition(int dur, TransitionDictionary tr) { duration = dur; trDictionary = tr; } /** * Returns the page width. * @return the page width */ public int getWidth() { return this.pagewidth; } /** * Returns the page height. * @return the page height */ public int getHeight() { return this.pageheight; } /** * @see org.apache.fop.pdf.PDFObject#toPDFString() */ public String toPDFString() { StringBuffer sb = new StringBuffer(); sb = sb.append(getObjectID() + "<< /Type /Page\n" + "/Parent " + this.parentRef + "\n" + "/MediaBox [ 0 0 " + getWidth() + " " + getHeight() + " ]\n" + "/Resources " + this.resources.referencePDF() + "\n" + "/Contents " + this.contents.referencePDF() + "\n"); if (this.annotList != null) { sb = sb.append("/Annots " + this.annotList.referencePDF() + "\n"); } if (this.duration != -1) { sb = sb.append("/Dur " + this.duration + "\n"); } if (this.trDictionary != null) { sb = sb.append("/Trans << " + this.trDictionary.getDictionary() + " >>\n"); } sb = sb.append(">>\nendobj\n"); return sb.toString(); } } tainer-nonimplemented.asciidoc?id=192e93a814f05dc8c5cc7a01b7264bc0a8a9dec7'>commitdiffstats

blob: 595085822f690a40865a08093ec8be05328fdffb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
---
title: Non-Implemented Methods
order: 8
layout: page
---

[[sqlcontainer.nonimplemented]]
= Non-Implemented Methods

Due to the database connection inherent to the SQLContainer, some of the methods
from the container interfaces of Vaadin can not (or would not make sense to) be
implemented. These methods are listed below, and they will throw an
[classname]#UnsupportedOperationException# on invocation.


----
public boolean addContainerProperty(Object propertyId,
                                    Class<?> type,
                                    Object defaultValue)
public boolean removeContainerProperty(Object propertyId)
public Item addItem(Object itemId)
public Object addItemAt(int index)
public Item addItemAt(int index, Object newItemId)
public Object addItemAfter(Object previousItemId)
public Item addItemAfter(Object previousItemId, Object newItemId)
----

Additionally, the following methods of the [classname]#Item# interface are not
supported in the [classname]#RowItem# class:


----
public boolean addItemProperty(Object id, Property property)
public boolean removeItemProperty(Object id)
----

[[sqlcontainer.nonimplemented.getitemids]]
== About the getItemIds() method

To properly implement the Vaadin [classname]#Container# interface, a
[methodname]#getItemIds()# method has been implented in the
[classname]#SQLContainer#. By definition, this method returns a collection of
all the item IDs present in the container. What this means in the
[classname]#SQLContainer# case is that the container has to query the database
for the primary key columns of all the rows present in the connected database
table.

It is obvious that this could potentially lead to fetching tens or even hundreds
of thousands of rows in an effort to satisfy the method caller. This will
effectively kill the lazy loading properties of [classname]#SQLContainer# and
therefore the following warning is expressed here:


[WARNING]
====
It is highly recommended not to call the [methodname]#getitemIds()# method,
unless it is known that in the use case in question the item ID set will always
be of reasonable size.

====