All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.lowagie.text.rtf.RtfTableCell Maven / Gradle / Ivy

There is a newer version: 4.2.2
Show newest version
/*
 * 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.rtf;

import com.lowagie.text.Cell;
import com.lowagie.text.Element;
import com.lowagie.text.BadElementException;

import java.util.Properties;

/**
 * A Cell with extended style attributes
 * 
 * ONLY FOR USE WITH THE RtfWriter NOT with the RtfWriter2.
 */
public class RtfTableCell extends Cell
{
    /* Table border styles */
    
    /** Table border solid */
    public static final int BORDER_UNDEFINED = 0;
    
    /** Table border solid */
    public static final int BORDER_SINGLE = 1;
    
    /** Table border double thickness */
    public static final int BORDER_DOUBLE_THICK = 2;
    
    /** Table border shadowed */
    public static final int BORDER_SHADOWED = 3;
    
    /** Table border dotted */
    public static final int BORDER_DOTTED = 4;
    
    /** Table border dashed */
    public static final int BORDER_DASHED = 5;
    
    /** Table border hairline */
    public static final int BORDER_HAIRLINE = 6;
    
    /** Table border double line */
    public static final int BORDER_DOUBLE = 7;
    
    /** Table border dot dash line */
    public static final int BORDER_DOT_DASH = 8;
    
    /** Table border dot dot dash line */
    public static final int BORDER_DOT_DOT_DASH = 9;
    
    /** Table border triple line */
    public static final int BORDER_TRIPLE = 10;

    /** Table border line */
    public static final int BORDER_THICK_THIN = 11;
    
    /** Table border line */
    public static final int BORDER_THIN_THICK = 12;
    
    /** Table border line */
    public static final int BORDER_THIN_THICK_THIN = 13;
    
    /** Table border line */
    public static final int BORDER_THICK_THIN_MED = 14;
    
    /** Table border line */
    public static final int BORDER_THIN_THICK_MED = 15;
    
    /** Table border line */
    public static final int BORDER_THIN_THICK_THIN_MED = 16;
    
    /** Table border line */
    public static final int BORDER_THICK_THIN_LARGE = 17;
    
    /** Table border line */
    public static final int BORDER_THIN_THICK_LARGE = 18;
    
    /** Table border line */
    public static final int BORDER_THIN_THICK_THIN_LARGE = 19;
    
    /** Table border line */
    public static final int BORDER_WAVY = 20;
    
    /** Table border line */
    public static final int BORDER_DOUBLE_WAVY = 21;
    
    /** Table border line */
    public static final int BORDER_STRIPED = 22;
    
    /** Table border line */
    public static final int BORDER_EMBOSS = 23;
    
    /** Table border line */
    public static final int BORDER_ENGRAVE = 24;
    
    /* Instance variables */
    private float topBorderWidth;
    private float leftBorderWidth;
    private float rightBorderWidth;
    private float bottomBorderWidth;
    private int topBorderStyle = 1;
    private int leftBorderStyle = 1;
    private int rightBorderStyle = 1;
    private int bottomBorderStyle = 1;
    
/**
 * Constructs an empty Cell (for internal use only).
 *
 * @param   dummy   a dummy value
 */

    public RtfTableCell(boolean dummy) {
        super(dummy);
    }
    
/**
 * Constructs a Cell with a certain Element.
 * 

* if the element is a ListItem, Row or * Cell, an exception will be thrown. * * @param element the element * @throws BadElementException when the creator was called with a ListItem, Row or Cell */ public RtfTableCell(Element element) throws BadElementException { super(element); } /** * Constructs a Cell with a certain content. *

* The String will be converted into a Paragraph. * * @param content a String */ public RtfTableCell(String content) { super(content); } /** * Returns a Cell that has been constructed taking in account * the value of some attributes. * * @param attributes Some attributes */ public RtfTableCell(Properties attributes) { super(attributes); } /** * Set all four borders to f width * * @param f the desired width */ public void setBorderWidth(float f) { super.setBorderWidth(f); topBorderWidth = f; leftBorderWidth = f; rightBorderWidth = f; bottomBorderWidth = f; } /** * Set the top border to f width * * @param f the desired width */ public void setTopBorderWidth(float f) { topBorderWidth = f; } /** * Get the top border width * @return a width */ public float topBorderWidth() { return topBorderWidth; } /** * Set the left border to f width * * @param f the desired width */ public void setLeftBorderWidth(float f) { leftBorderWidth = f; } /** * Get the left border width * @return a width */ public float leftBorderWidth() { return leftBorderWidth; } /** * Set the right border to f width * * @param f the desired width */ public void setRightBorderWidth(float f) { rightBorderWidth = f; } /** * Get the right border width * @return a width */ public float rightBorderWidth() { return rightBorderWidth; } /** * Set the bottom border to f width * * @param f the desired width */ public void setBottomBorderWidth(float f) { bottomBorderWidth = f; } /** * Get the bottom border width * @return a width */ public float bottomBorderWidth() { return bottomBorderWidth; } /** * Set all four borders to style defined by style * * @param style the desired style */ public void setBorderStyle(int style) { topBorderStyle = style; leftBorderStyle = style; rightBorderStyle = style; bottomBorderStyle = style; } /** * Set the top border to style defined by style * * @param style the desired style */ public void setTopBorderStyle(int style) { topBorderStyle = style; } /** * Get the top border style * @return a style value */ public int topBorderStyle() { return topBorderStyle; } /** * Set the left border to style defined by style * * @param style the desired style */ public void setLeftBorderStyle(int style) { leftBorderStyle = style; } /** * Get the left border style * @return a style value */ public int leftBorderStyle() { return leftBorderStyle; } /** * Set the right border to style defined by style * * @param style the desired style */ public void setRightBorderStyle(int style) { rightBorderStyle = style; } /** * Get the right border style * @return a style value */ public int rightBorderStyle() { return rightBorderStyle; } /** * Set the bottom border to style defined by style * * @param style the desired style */ public void setBottomBorderStyle(int style) { bottomBorderStyle = style; } /** * Get the bottom border style * @return a style value */ public int bottomBorderStyle() { return bottomBorderStyle; } /** * Get the RTF control word for style * @param style a style value * @return a byte array corresponding with a style control word */ protected static byte[] getStyleControlWord(int style) { switch(style) { case BORDER_UNDEFINED : return "brdrs".getBytes(); case BORDER_SINGLE : return "brdrs".getBytes(); case BORDER_DOUBLE_THICK : return "brdrth".getBytes(); case BORDER_SHADOWED : return "brdrsh".getBytes(); case BORDER_DOTTED : return "brdrdot".getBytes(); case BORDER_DASHED : return "brdrdash".getBytes(); case BORDER_HAIRLINE : return "brdrhair".getBytes(); case BORDER_DOUBLE : return "brdrdb".getBytes(); case BORDER_DOT_DASH : return "brdrdashd".getBytes(); case BORDER_DOT_DOT_DASH : return "brdrdashdd".getBytes(); case BORDER_TRIPLE : return "brdrtriple".getBytes(); case BORDER_THICK_THIN : return "brdrtnthsg".getBytes(); case BORDER_THIN_THICK : return "brdrthtnsg".getBytes(); case BORDER_THIN_THICK_THIN : return "brdrtnthtnsg".getBytes(); case BORDER_THICK_THIN_MED : return "brdrtnthmg".getBytes(); case BORDER_THIN_THICK_MED : return "brdrthtnmg".getBytes(); case BORDER_THIN_THICK_THIN_MED : return "brdrtnthtnmg".getBytes(); case BORDER_THICK_THIN_LARGE : return "brdrtnthlg".getBytes(); case BORDER_THIN_THICK_LARGE : return "brdrthtnlg".getBytes(); case BORDER_THIN_THICK_THIN_LARGE : return "brdrtnthtnlg".getBytes(); case BORDER_WAVY : return "brdrwavy".getBytes(); case BORDER_DOUBLE_WAVY : return "brdrwavydb".getBytes(); case BORDER_STRIPED : return "brdrdashdotstr".getBytes(); case BORDER_EMBOSS : return "brdremboss".getBytes(); case BORDER_ENGRAVE : return "brdrengrave".getBytes(); } return "brdrs".getBytes(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy