com.lowagie.text.rtf.style.RtfFont Maven / Gradle / Ivy
Show all versions of rtf-gen Show documentation
/*
* $Id: RtfFont.java 4008 2009-07-07 09:56:52Z blowagie $
*
* Copyright 2001, 2002, 2003, 2004 by Mark Hall
*
* 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:
* https://github.com/osobolev/rtf-gen
*/
package com.lowagie.text.rtf.style;
import com.lowagie.text.DocWriter;
import com.lowagie.text.Font;
import com.lowagie.text.rtf.RtfExtendedElement;
import com.lowagie.text.rtf.document.RtfDocument;
import java.awt.Color;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Objects;
import static com.lowagie.text.rtf.RtfElement.intToByteArray;
/**
* The RtfFont class stores one font for an rtf document. It extends Font,
* so can be set as a font, to allow adding of fonts with arbitrary names.
* BaseFont fontname handling contributed by Craig Fleming. Various fixes
* Renaud Michel, Werner Daehn.
*
* Version: $Id: RtfFont.java 4008 2009-07-07 09:56:52Z blowagie $
*
* @author Mark Hall ([email protected])
* @author Craig Fleming ([email protected])
* @author Renaud Michel ([email protected])
* @author Werner Daehn ([email protected])
* @author Lidong Liu ([email protected])
* @author Thomas Bickel ([email protected])
*/
public class RtfFont extends Font implements RtfExtendedElement {
/**
* Constant for the font family to use ("froman")
*/
private static final byte[] FONT_FAMILY = DocWriter.getISOBytes("\\froman");
/**
* Constant for the charset
*/
private static final byte[] FONT_CHARSET = DocWriter.getISOBytes("\\fcharset");
/**
* Constant for the font size
*/
public static final byte[] FONT_SIZE = DocWriter.getISOBytes("\\fs");
/**
* Constant for the bold flag
*/
private static final byte[] FONT_BOLD = DocWriter.getISOBytes("\\b");
/**
* Constant for the italic flag
*/
private static final byte[] FONT_ITALIC = DocWriter.getISOBytes("\\i");
/**
* Constant for the underline flag
*/
private static final byte[] FONT_UNDERLINE = DocWriter.getISOBytes("\\ul");
/**
* Constant for the strikethrough flag
*/
private static final byte[] FONT_STRIKETHROUGH = DocWriter.getISOBytes("\\strike");
/**
* Constant for the double strikethrough flag
*/
private static final byte[] FONT_DOUBLE_STRIKETHROUGH = DocWriter.getISOBytes("\\striked");
/**
* Constant for the shadow flag
*/
private static final byte[] FONT_SHADOW = DocWriter.getISOBytes("\\shad");
/**
* Constant for the outline flag
*/
private static final byte[] FONT_OUTLINE = DocWriter.getISOBytes("\\outl");
/**
* Constant for the embossed flag
*/
private static final byte[] FONT_EMBOSSED = DocWriter.getISOBytes("\\embo");
/**
* Constant for the engraved flag
*/
private static final byte[] FONT_ENGRAVED = DocWriter.getISOBytes("\\impr");
/**
* Constant for hidden text flag
*/
private static final byte[] FONT_HIDDEN = DocWriter.getISOBytes("\\v");
/**
* Constant for a plain font
*/
public static final int STYLE_NONE = 0;
/**
* Constant for a bold font
*/
public static final int STYLE_BOLD = 1;
/**
* Constant for an italic font
*/
public static final int STYLE_ITALIC = 2;
/**
* Constant for an underlined font
*/
public static final int STYLE_UNDERLINE = 4;
/**
* Constant for a strikethrough font
*/
public static final int STYLE_STRIKETHROUGH = 8;
/**
* Constant for a double strikethrough font
*/
public static final int STYLE_DOUBLE_STRIKETHROUGH = 16;
/**
* Constant for a shadowed font
*/
public static final int STYLE_SHADOW = 32;
/**
* Constant for an outlined font
*/
public static final int STYLE_OUTLINE = 64;
/**
* Constant for an embossed font
*/
public static final int STYLE_EMBOSSED = 128;
/**
* Constant for an engraved font
*/
public static final int STYLE_ENGRAVED = 256;
/**
* Constant for a font that hides the actual text.
*/
public static final int STYLE_HIDDEN = 512;
/**
* Default font
*
* @since 2.1.7
*/
public static final String DEFAULT_FONT = "Times New Roman";
/**
* The font name. Defaults to "Times New Roman"
*/
private String fontName = DEFAULT_FONT;
/**
* The font size. Defaults to 10
*/
private int fontSize = 10;
/**
* The font style. Defaults to STYLE_NONE
*/
private int fontStyle = STYLE_NONE;
/**
* The number of this font
*/
private int fontNumber = 0;
/**
* The color of this font
*/
private RtfColor color = null;
/**
* The character set to use for this font
*/
private int charset = 0;
/**
* The RtfDocument this RtfFont belongs to.
*/
protected RtfDocument document = null;
/**
* Constructs a RtfFont with the given font name and all other properties
* at their default values.
*
* @param fontName The font name to use
*/
public RtfFont(String fontName) {
super(Font.UNDEFINED, Font.UNDEFINED, Font.UNDEFINED, null);
this.fontName = fontName;
}
/**
* Constructs a RtfFont with the given font name and font size and all other
* properties at their default values.
*
* @param fontName The font name to use
* @param size The font size to use
*/
public RtfFont(String fontName, float size) {
super(Font.UNDEFINED, size, Font.UNDEFINED, null);
this.fontName = fontName;
}
/**
* Constructs a RtfFont with the given font name, font size and font style and the
* default color.
*
* @param fontName The font name to use
* @param size The font size to use
* @param style The font style to use
*/
public RtfFont(String fontName, float size, int style) {
super(Font.UNDEFINED, size, style, null);
this.fontName = fontName;
}
/**
* Constructs a RtfFont with the given font name, font size, font style and
* color.
*
* @param fontName The font name to use
* @param size the font size to use
* @param style The font style to use
* @param color The font color to use
*/
public RtfFont(String fontName, float size, int style, Color color) {
super(Font.UNDEFINED, size, style, color);
this.fontName = fontName;
}
/**
* Constructs a RtfFont with the given font name, font size, font style, color
* and charset. This can be used when generating non latin-1 text.
*
* @param fontName The font name to use
* @param size the font size to use
* @param style The font style to use
* @param color The font color to use
* @param charset The charset of the font content
*/
public RtfFont(String fontName, float size, int style, Color color, int charset) {
this(fontName, size, style, color);
this.charset = charset;
}
/**
* Special constructor for the default font
*
* @param doc The RtfDocument this font appears in
* @param fontNumber The id of this font
*/
protected RtfFont(RtfDocument doc, int fontNumber) {
this.document = doc;
this.fontNumber = fontNumber;
color = new RtfColor(doc, 0, 0, 0);
}
/**
* Constructs a RtfFont from a com.lowagie.text.Font
*
* @param doc The RtfDocument this font appears in
* @param font The Font to use as a base
*/
public RtfFont(RtfDocument doc, Font font) {
this.document = doc;
if (font != null) {
if (font instanceof RtfFont) {
this.fontName = ((RtfFont) font).getFontName();
this.charset = ((RtfFont) font).getCharset();
} else {
setToDefaultFamily(font.getFamilyname());
}
if ("unknown".equalsIgnoreCase(this.fontName)) {
this.fontName = DEFAULT_FONT;
}
setSize(font.getSize());
setStyle(font.getStyle());
setColor(font.getColor());
if (document != null) {
this.fontNumber = document.getDocumentHeader().getFontNumber(this);
}
}
if (document != null) {
setRtfDocument(document);
}
}
/**
* Writes the font definition
*/
@Override
public void writeDefinition(OutputStream result) throws IOException {
result.write(FONT_FAMILY);
result.write(FONT_CHARSET);
result.write(intToByteArray(charset));
result.write(DELIMITER);
document.filterSpecialChar(result, fontName, true, false);
}
/**
* Writes the font beginning
*
* @param result The OutputStream
to write to.
* @throws IOException On i/o errors.
*/
public void writeBegin(OutputStream result) throws IOException {
if (this.fontNumber != Font.UNDEFINED) {
result.write(RtfFontList.FONT_NUMBER);
result.write(intToByteArray(fontNumber));
}
if (this.fontSize != Font.UNDEFINED) {
result.write(FONT_SIZE);
result.write(intToByteArray(fontSize * 2));
}
if (this.fontStyle != UNDEFINED) {
if ((fontStyle & STYLE_BOLD) == STYLE_BOLD) {
result.write(FONT_BOLD);
}
if ((fontStyle & STYLE_ITALIC) == STYLE_ITALIC) {
result.write(FONT_ITALIC);
}
if ((fontStyle & STYLE_UNDERLINE) == STYLE_UNDERLINE) {
result.write(FONT_UNDERLINE);
}
if ((fontStyle & STYLE_STRIKETHROUGH) == STYLE_STRIKETHROUGH) {
result.write(FONT_STRIKETHROUGH);
}
if ((fontStyle & STYLE_HIDDEN) == STYLE_HIDDEN) {
result.write(FONT_HIDDEN);
}
if ((fontStyle & STYLE_DOUBLE_STRIKETHROUGH) == STYLE_DOUBLE_STRIKETHROUGH) {
result.write(FONT_DOUBLE_STRIKETHROUGH);
result.write(intToByteArray(1));
}
if ((fontStyle & STYLE_SHADOW) == STYLE_SHADOW) {
result.write(FONT_SHADOW);
}
if ((fontStyle & STYLE_OUTLINE) == STYLE_OUTLINE) {
result.write(FONT_OUTLINE);
}
if ((fontStyle & STYLE_EMBOSSED) == STYLE_EMBOSSED) {
result.write(FONT_EMBOSSED);
}
if ((fontStyle & STYLE_ENGRAVED) == STYLE_ENGRAVED) {
result.write(FONT_ENGRAVED);
}
}
if (color != null) {
color.writeBegin(result);
}
}
/**
* Write the font end
*
* @param result The OutputStream
to write to.
* @throws IOException On i/o errors.
*/
public void writeEnd(OutputStream result) throws IOException {
if (this.fontStyle != UNDEFINED) {
if ((fontStyle & STYLE_BOLD) == STYLE_BOLD) {
result.write(FONT_BOLD);
result.write(intToByteArray(0));
}
if ((fontStyle & STYLE_ITALIC) == STYLE_ITALIC) {
result.write(FONT_ITALIC);
result.write(intToByteArray(0));
}
if ((fontStyle & STYLE_UNDERLINE) == STYLE_UNDERLINE) {
result.write(FONT_UNDERLINE);
result.write(intToByteArray(0));
}
if ((fontStyle & STYLE_STRIKETHROUGH) == STYLE_STRIKETHROUGH) {
result.write(FONT_STRIKETHROUGH);
result.write(intToByteArray(0));
}
if ((fontStyle & STYLE_HIDDEN) == STYLE_HIDDEN) {
result.write(FONT_HIDDEN);
result.write(intToByteArray(0));
}
if ((fontStyle & STYLE_DOUBLE_STRIKETHROUGH) == STYLE_DOUBLE_STRIKETHROUGH) {
result.write(FONT_DOUBLE_STRIKETHROUGH);
result.write(intToByteArray(0));
}
if ((fontStyle & STYLE_SHADOW) == STYLE_SHADOW) {
result.write(FONT_SHADOW);
result.write(intToByteArray(0));
}
if ((fontStyle & STYLE_OUTLINE) == STYLE_OUTLINE) {
result.write(FONT_OUTLINE);
result.write(intToByteArray(0));
}
if ((fontStyle & STYLE_EMBOSSED) == STYLE_EMBOSSED) {
result.write(FONT_EMBOSSED);
result.write(intToByteArray(0));
}
if ((fontStyle & STYLE_ENGRAVED) == STYLE_ENGRAVED) {
result.write(FONT_ENGRAVED);
result.write(intToByteArray(0));
}
}
}
/**
* unused
*/
@Override
public void writeContent(OutputStream out) {
}
/**
* Tests for equality of RtfFonts. RtfFonts are equal if their fontName,
* fontSize, fontStyle and fontSuperSubscript are equal
*
* @param obj The RtfFont to compare with this RtfFont
* @return True
if the RtfFonts are equal, false
otherwise
*/
@Override
public boolean equals(Object obj) {
if (!(obj instanceof RtfFont)) {
return false;
}
RtfFont font = (RtfFont) obj;
return this.fontName.equals(font.getFontName());
}
/**
* Returns the hash code of this RtfFont. The hash code is the hash code of the
* string containing the font name + font size + "-" + the font style + "-" + the
* font super/supscript value.
*
* @return The hash code of this RtfFont
*/
@Override
public int hashCode() {
return (this.fontName + this.fontSize + "-" + this.fontStyle).hashCode();
}
/**
* Gets the font name of this RtfFont
*
* @return The font name
*/
public String getFontName() {
return this.fontName;
}
/**
* Sets the font name of this RtfFont.
*
* @param fontName The font name to use
*/
protected void setFontName(String fontName) {
this.fontName = fontName;
if (document != null) {
this.fontNumber = document.getDocumentHeader().getFontNumber(this);
}
}
/**
* @see com.lowagie.text.Font#getFamilyname()
*/
@Override
public String getFamilyname() {
return this.fontName;
}
/**
* @see com.lowagie.text.Font#setFamily(String)
*/
@Override
public void setFamily(String family) {
super.setFamily(family);
setToDefaultFamily(family);
}
/**
* Sets the correct font name from the family name.
*
* @param familyname The family name to set the name to.
*/
private void setToDefaultFamily(String familyname) {
switch (Font.getFamilyIndex(familyname)) {
case Font.COURIER:
this.fontName = "Courier";
break;
case Font.HELVETICA:
this.fontName = "Arial";
break;
case Font.SYMBOL:
this.fontName = "Symbol";
this.charset = 2;
break;
case Font.TIMES_ROMAN:
this.fontName = "Times New Roman";
break;
case Font.ZAPFDINGBATS:
this.fontName = "Windings";
break;
default:
this.fontName = familyname;
}
}
/**
* Gets the font size of this RtfFont
*
* @return The font size
*/
public int getFontSize() {
return this.fontSize;
}
/**
* @see com.lowagie.text.Font#setSize(float)
*/
@Override
public void setSize(float size) {
super.setSize(size);
this.fontSize = (int) getSize();
}
/**
* Gets the font style of this RtfFont
*
* @return The font style
*/
public int getFontStyle() {
return this.fontStyle;
}
/**
* @see com.lowagie.text.Font#setStyle(int)
*/
@Override
public void setStyle(int style) {
super.setStyle(style);
this.fontStyle = getStyle();
}
/**
* @see com.lowagie.text.Font#setStyle(String)
*/
@Override
public void setStyle(String style) {
super.setStyle(style);
fontStyle = getStyle();
}
/**
* Gets the charset used for constructing this RtfFont.
*
* @return The charset of this RtfFont.
*/
public int getCharset() {
return charset;
}
/**
* Sets the charset used for constructing this RtfFont.
*
* @param charset The charset to use.
*/
public void setCharset(int charset) {
this.charset = charset;
}
/**
* Gets the font number of this RtfFont
*
* @return The font number
*/
public int getFontNumber() {
return fontNumber;
}
/**
* Sets the RtfDocument this RtfFont belongs to
*
* @param doc The RtfDocument to use
*/
@Override
public void setRtfDocument(RtfDocument doc) {
this.document = doc;
if (document != null) {
this.fontNumber = document.getDocumentHeader().getFontNumber(this);
}
if (this.color != null) {
this.color.setRtfDocument(this.document);
}
}
/**
* Unused
*
* @param inTable
*/
@Override
public void setInTable(boolean inTable) {
}
/**
* Unused
*
* @param inHeader
*/
@Override
public void setInHeader(boolean inHeader) {
}
/**
* @see com.lowagie.text.Font#setColor(Color)
*/
@Override
public void setColor(Color color) {
super.setColor(color);
if (color != null) {
this.color = new RtfColor(document, color);
} else {
this.color = null;
}
}
/**
* @see com.lowagie.text.Font#setColor(int, int, int)
*/
@Override
public void setColor(int red, int green, int blue) {
super.setColor(red, green, blue);
this.color = new RtfColor(document, red, green, blue);
}
/**
* Replaces the attributes that are equal to null with
* the attributes of a given font.
*
* @param font The surrounding font
* @return A RtfFont
*/
@Override
public Font difference(Font font) {
String dFamilyname = font.getFamilyname();
if (dFamilyname == null || "".equals(dFamilyname.trim()) || "unknown".equalsIgnoreCase(dFamilyname.trim())) {
dFamilyname = this.fontName;
}
float dSize = font.getSize();
if (dSize == Font.UNDEFINED) {
dSize = this.getSize();
}
int dStyle = Font.UNDEFINED;
if (this.getStyle() != Font.UNDEFINED && font.getStyle() != Font.UNDEFINED) {
dStyle = this.getStyle() | font.getStyle();
} else if (this.getStyle() != Font.UNDEFINED) {
dStyle = this.getStyle();
} else if (font.getStyle() != Font.UNDEFINED) {
dStyle = font.getStyle();
}
Color dColor = font.getColor();
if (dColor == null) {
dColor = this.getColor();
}
int dCharset = this.charset;
if (font instanceof RtfFont) {
dCharset = ((RtfFont) font).getCharset();
}
return new RtfFont(dFamilyname, dSize, dStyle, dColor, dCharset);
}
/**
* The RtfFont
is never a standard font.
*
* @since 2.1.0
*/
@Override
public boolean isStandardFont() {
return false;
}
@Override
public boolean same(Font that) {
if (this == that)
return true;
if (that instanceof RtfFont) {
if (!Objects.equals(this.fontName, ((RtfFont) that).fontName))
return false;
}
return super.same(that);
}
}