⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pdfannotation.java

📁 处理PDF
💻 JAVA
📖 第 1 页 / 共 3 页
字号:
/* * $Id: PdfAnnotation.java 3425 2008-05-24 16:06:00Z xlv $ * * Copyright 1999, 2000, 2001, 2002 Bruno Lowagie * * The contents of this file are subject to the Mozilla Public License Version 1.1 * (the "License"); you may not use this file except in compliance with the License. * You may obtain a copy of the License at http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the License. * * The Original Code is 'iText, a free JAVA-PDF library'. * * The Initial Developer of the Original Code is Bruno Lowagie. Portions created by * the Initial Developer are Copyright (C) 1999, 2000, 2001, 2002 by Bruno Lowagie. * All Rights Reserved. * Co-Developer of the code is Paulo Soares. Portions created by the Co-Developer * are Copyright (C) 2000, 2001, 2002 by Paulo Soares. All Rights Reserved. * * Contributor(s): all the names of the contributors are added in the source code * where applicable. * * Alternatively, the contents of this file may be used under the terms of the * LGPL license (the "GNU LIBRARY GENERAL PUBLIC LICENSE"), in which case the * provisions of LGPL are applicable instead of those above.  If you wish to * allow use of your version of this file only under the terms of the LGPL * License and not to allow others to use your version of this file under * the MPL, indicate your decision by deleting the provisions above and * replace them with the notice and other provisions required by the LGPL. * If you do not delete the provisions above, a recipient may use your version * of this file under either the MPL or the GNU LIBRARY GENERAL PUBLIC LICENSE. * * This library is free software; you can redistribute it and/or modify it * under the terms of the MPL as stated above or under the terms of the GNU * Library General Public License as published by the Free Software Foundation; * either version 2 of the License, or any later version. * * This library is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU Library general Public License for more * details. * * If you didn't download this code from the following link, you should check if * you aren't using an obsolete version: * http://www.lowagie.com/iText/ */package com.lowagie.text.pdf;import java.awt.Color;import java.io.IOException;import java.util.HashMap;import com.lowagie.text.Rectangle;/** * A <CODE>PdfAnnotation</CODE> is a note that is associated with a page. * * @see		PdfDictionary */public class PdfAnnotation extends PdfDictionary {    /** highlight attributename */    public static final PdfName HIGHLIGHT_NONE = PdfName.N;    /** highlight attributename */    public static final PdfName HIGHLIGHT_INVERT = PdfName.I;    /** highlight attributename */    public static final PdfName HIGHLIGHT_OUTLINE = PdfName.O;    /** highlight attributename */    public static final PdfName HIGHLIGHT_PUSH = PdfName.P;    /** highlight attributename */    public static final PdfName HIGHLIGHT_TOGGLE = PdfName.T;    /** flagvalue */    public static final int FLAGS_INVISIBLE = 1;    /** flagvalue */    public static final int FLAGS_HIDDEN = 2;    /** flagvalue */    public static final int FLAGS_PRINT = 4;    /** flagvalue */    public static final int FLAGS_NOZOOM = 8;    /** flagvalue */    public static final int FLAGS_NOROTATE = 16;    /** flagvalue */    public static final int FLAGS_NOVIEW = 32;    /** flagvalue */    public static final int FLAGS_READONLY = 64;    /** flagvalue */    public static final int FLAGS_LOCKED = 128;    /** flagvalue */    public static final int FLAGS_TOGGLENOVIEW = 256;    /** appearance attributename */    public static final PdfName APPEARANCE_NORMAL = PdfName.N;    /** appearance attributename */    public static final PdfName APPEARANCE_ROLLOVER = PdfName.R;    /** appearance attributename */    public static final PdfName APPEARANCE_DOWN = PdfName.D;    /** attributevalue */    public static final PdfName AA_ENTER = PdfName.E;    /** attributevalue */    public static final PdfName AA_EXIT = PdfName.X;    /** attributevalue */    public static final PdfName AA_DOWN = PdfName.D;    /** attributevalue */    public static final PdfName AA_UP = PdfName.U;    /** attributevalue */    public static final PdfName AA_FOCUS = PdfName.FO;    /** attributevalue */    public static final PdfName AA_BLUR = PdfName.BL;    /** attributevalue */    public static final PdfName AA_JS_KEY = PdfName.K;    /** attributevalue */    public static final PdfName AA_JS_FORMAT = PdfName.F;    /** attributevalue */    public static final PdfName AA_JS_CHANGE = PdfName.V;    /** attributevalue */    public static final PdfName AA_JS_OTHER_CHANGE = PdfName.C;    /** attributevalue */    public static final int MARKUP_HIGHLIGHT = 0;    /** attributevalue */    public static final int MARKUP_UNDERLINE = 1;    /** attributevalue */    public static final int MARKUP_STRIKEOUT = 2;    /**     * attributevalue     * @since 2.1.3     */    public static final int MARKUP_SQUIGGLY = 3;        protected PdfWriter writer;    protected PdfIndirectReference reference;    protected HashMap templates;    protected boolean form = false;    protected boolean annotation = true;        /** Holds value of property used. */    protected boolean used = false;        /** Holds value of property placeInPage. */    private int placeInPage = -1;        // constructors    public PdfAnnotation(PdfWriter writer, Rectangle rect) {        this.writer = writer;        if (rect != null)            put(PdfName.RECT, new PdfRectangle(rect));    }    /** * Constructs a new <CODE>PdfAnnotation</CODE> of subtype text. * @param writer * @param llx * @param lly * @param urx * @param ury * @param title * @param content */        public PdfAnnotation(PdfWriter writer, float llx, float lly, float urx, float ury, PdfString title, PdfString content) {        this.writer = writer;        put(PdfName.SUBTYPE, PdfName.TEXT);        put(PdfName.T, title);        put(PdfName.RECT, new PdfRectangle(llx, lly, urx, ury));        put(PdfName.CONTENTS, content);    }    /** * Constructs a new <CODE>PdfAnnotation</CODE> of subtype link (Action). * @param writer * @param llx * @param lly * @param urx * @param ury * @param action */        public PdfAnnotation(PdfWriter writer, float llx, float lly, float urx, float ury, PdfAction action) {        this.writer = writer;        put(PdfName.SUBTYPE, PdfName.LINK);        put(PdfName.RECT, new PdfRectangle(llx, lly, urx, ury));        put(PdfName.A, action);        put(PdfName.BORDER, new PdfBorderArray(0, 0, 0));        put(PdfName.C, new PdfColor(0x00, 0x00, 0xFF));    }    /**     * Creates a screen PdfAnnotation     * @param writer     * @param rect     * @param clipTitle     * @param fs     * @param mimeType     * @param playOnDisplay     * @return a screen PdfAnnotation     * @throws IOException     */    public static PdfAnnotation createScreen(PdfWriter writer, Rectangle rect, String clipTitle, PdfFileSpecification fs,                                             String mimeType, boolean playOnDisplay) throws IOException {        PdfAnnotation ann = new PdfAnnotation(writer, rect);        ann.put(PdfName.SUBTYPE, PdfName.SCREEN);        ann.put (PdfName.F, new PdfNumber(FLAGS_PRINT));        ann.put(PdfName.TYPE, PdfName.ANNOT);        ann.setPage();        PdfIndirectReference ref = ann.getIndirectReference();        PdfAction action = PdfAction.rendition(clipTitle,fs,mimeType, ref);        PdfIndirectReference actionRef = writer.addToBody(action).getIndirectReference();        // for play on display add trigger event        if (playOnDisplay)        {            PdfDictionary aa = new PdfDictionary();            aa.put(new PdfName("PV"), actionRef);            ann.put(PdfName.AA, aa);        }        ann.put(PdfName.A, actionRef);        return ann;    }    public PdfIndirectReference getIndirectReference() {        if (reference == null) {            reference = writer.getPdfIndirectReference();        }        return reference;    }        /**     * @param writer     * @param rect     * @param title     * @param contents     * @param open     * @param icon     * @return a PdfAnnotation     */    public static PdfAnnotation createText(PdfWriter writer, Rectangle rect, String title, String contents, boolean open, String icon) {        PdfAnnotation annot = new PdfAnnotation(writer, rect);        annot.put(PdfName.SUBTYPE, PdfName.TEXT);        if (title != null)            annot.put(PdfName.T, new PdfString(title, PdfObject.TEXT_UNICODE));        if (contents != null)            annot.put(PdfName.CONTENTS, new PdfString(contents, PdfObject.TEXT_UNICODE));        if (open)            annot.put(PdfName.OPEN, PdfBoolean.PDFTRUE);        if (icon != null) {            annot.put(PdfName.NAME, new PdfName(icon));        }        return annot;    }        /**     * Creates a link.     * @param writer     * @param rect     * @param highlight     * @return A PdfAnnotation     */    protected static PdfAnnotation createLink(PdfWriter writer, Rectangle rect, PdfName highlight) {        PdfAnnotation annot = new PdfAnnotation(writer, rect);        annot.put(PdfName.SUBTYPE, PdfName.LINK);        if (!highlight.equals(HIGHLIGHT_INVERT))            annot.put(PdfName.H, highlight);        return annot;    }        /**     * Creates an Annotation with an Action.     * @param writer     * @param rect     * @param highlight     * @param action     * @return A PdfAnnotation     */    public static PdfAnnotation createLink(PdfWriter writer, Rectangle rect, PdfName highlight, PdfAction action) {        PdfAnnotation annot = createLink(writer, rect, highlight);        annot.putEx(PdfName.A, action);        return annot;    }    /**     * Creates an Annotation with an local destination.     * @param writer     * @param rect     * @param highlight     * @param namedDestination     * @return A PdfAnnotation     */    public static PdfAnnotation createLink(PdfWriter writer, Rectangle rect, PdfName highlight, String namedDestination) {        PdfAnnotation annot = createLink(writer, rect, highlight);        annot.put(PdfName.DEST, new PdfString(namedDestination));        return annot;    }    /**     * Creates an Annotation with a PdfDestination.     * @param writer     * @param rect     * @param highlight

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -