Initial Commit
This commit is contained in:
326
iTechSharp/iTextSharp/text/rtf/headerfooter/RtfHeaderFooter.cs
Normal file
326
iTechSharp/iTextSharp/text/rtf/headerfooter/RtfHeaderFooter.cs
Normal file
@@ -0,0 +1,326 @@
|
||||
using System;
|
||||
using System.IO;
|
||||
using iTextSharp.text;
|
||||
using iTextSharp.text.rtf;
|
||||
using iTextSharp.text.rtf.document;
|
||||
using FD = iTextSharp.text.rtf.field;
|
||||
/*
|
||||
* Created on Aug 10, 2004
|
||||
*
|
||||
* To change the template for this generated file go to
|
||||
* Window - Preferences - Java - Code Generation - Code and Comments
|
||||
*/
|
||||
namespace iTextSharp.text.rtf.headerfooter {
|
||||
|
||||
/**
|
||||
* The RtfHeaderFooter represents one header or footer. This class can be used
|
||||
* directly.
|
||||
*
|
||||
* @version $Id: RtfHeaderFooter.cs,v 1.7 2008/05/16 19:30:59 psoares33 Exp $
|
||||
* @author Mark Hall (Mark.Hall@mail.room3b.eu)
|
||||
*/
|
||||
public class RtfHeaderFooter : HeaderFooter, IRtfBasicElement {
|
||||
|
||||
/**
|
||||
* Constant for the header type
|
||||
*/
|
||||
public const int TYPE_HEADER = 1;
|
||||
/**
|
||||
* Constant for the footer type
|
||||
*/
|
||||
public const int TYPE_FOOTER = 2;
|
||||
/**
|
||||
* Constant for displaying the header/footer on the first page
|
||||
*/
|
||||
public const int DISPLAY_FIRST_PAGE = 0;
|
||||
/**
|
||||
* Constant for displaying the header/footer on all pages
|
||||
*/
|
||||
public const int DISPLAY_ALL_PAGES = 1;
|
||||
/**
|
||||
* Constant for displaying the header/footer on all left hand pages
|
||||
*/
|
||||
public const int DISPLAY_LEFT_PAGES = 2;
|
||||
/**
|
||||
* Constant for displaying the header/footer on all right hand pages
|
||||
*/
|
||||
public const int DISPLAY_RIGHT_PAGES = 4;
|
||||
|
||||
/**
|
||||
* Constant for a header on all pages
|
||||
*/
|
||||
private static byte[] HEADER_ALL = DocWriter.GetISOBytes("\\header");
|
||||
/**
|
||||
* Constant for a header on the first page
|
||||
*/
|
||||
private static byte[] HEADER_FIRST = DocWriter.GetISOBytes("\\headerf");
|
||||
/**
|
||||
* Constant for a header on all left hand pages
|
||||
*/
|
||||
private static byte[] HEADER_LEFT = DocWriter.GetISOBytes("\\headerl");
|
||||
/**
|
||||
* Constant for a header on all right hand pages
|
||||
*/
|
||||
private static byte[] HEADER_RIGHT = DocWriter.GetISOBytes("\\headerr");
|
||||
/**
|
||||
* Constant for a footer on all pages
|
||||
*/
|
||||
private static byte[] FOOTER_ALL = DocWriter.GetISOBytes("\\footer");
|
||||
/**
|
||||
* Constant for a footer on the first page
|
||||
*/
|
||||
private static byte[] FOOTER_FIRST = DocWriter.GetISOBytes("\\footerf");
|
||||
/**
|
||||
* Constnat for a footer on the left hand pages
|
||||
*/
|
||||
private static byte[] FOOTER_LEFT = DocWriter.GetISOBytes("\\footerl");
|
||||
/**
|
||||
* Constant for a footer on the right hand pages
|
||||
*/
|
||||
private static byte[] FOOTER_RIGHT = DocWriter.GetISOBytes("\\footerr");
|
||||
|
||||
/**
|
||||
* The RtfDocument this RtfHeaderFooter belongs to
|
||||
*/
|
||||
private RtfDocument document = null;
|
||||
/**
|
||||
* The content of this RtfHeaderFooter
|
||||
*/
|
||||
private Object[] content = null;
|
||||
/**
|
||||
* The display type of this RtfHeaderFooter. TYPE_HEADER or TYPE_FOOTER
|
||||
*/
|
||||
private int type = TYPE_HEADER;
|
||||
/**
|
||||
* The display location of this RtfHeaderFooter. DISPLAY_FIRST_PAGE,
|
||||
* DISPLAY_LEFT_PAGES, DISPLAY_RIGHT_PAGES or DISPLAY_ALL_PAGES
|
||||
*/
|
||||
private int displayAt = DISPLAY_ALL_PAGES;
|
||||
|
||||
/**
|
||||
* Constructs a RtfHeaderFooter based on a HeaderFooter with a certain type and displayAt
|
||||
* location. For internal use only.
|
||||
*
|
||||
* @param doc The RtfDocument this RtfHeaderFooter belongs to
|
||||
* @param headerFooter The HeaderFooter to base this RtfHeaderFooter on
|
||||
* @param type The type of RtfHeaderFooter
|
||||
* @param displayAt The display location of this RtfHeaderFooter
|
||||
*/
|
||||
protected internal RtfHeaderFooter(RtfDocument doc, HeaderFooter headerFooter, int type, int displayAt) : base(new Phrase(""), false) {
|
||||
this.document = doc;
|
||||
this.type = type;
|
||||
this.displayAt = displayAt;
|
||||
Paragraph par = new Paragraph();
|
||||
par.Alignment = headerFooter.Alignment;
|
||||
if (headerFooter.Before != null) {
|
||||
par.Add(headerFooter.Before);
|
||||
}
|
||||
if (headerFooter.IsNumbered()) {
|
||||
par.Add(new FD.RtfPageNumber(this.document));
|
||||
}
|
||||
if (headerFooter.After != null) {
|
||||
par.Add(headerFooter.After);
|
||||
}
|
||||
try {
|
||||
this.content = new Object[1];
|
||||
if (this.document != null) {
|
||||
this.content[0] = this.document.GetMapper().MapElement(par)[0];
|
||||
((IRtfBasicElement) this.content[0]).SetInHeader(true);
|
||||
} else {
|
||||
this.content[0] = par;
|
||||
}
|
||||
} catch (DocumentException) {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs a RtfHeaderFooter as a copy of an existing RtfHeaderFooter.
|
||||
* For internal use only.
|
||||
*
|
||||
* @param doc The RtfDocument this RtfHeaderFooter belongs to
|
||||
* @param headerFooter The RtfHeaderFooter to copy
|
||||
* @param displayAt The display location of this RtfHeaderFooter
|
||||
*/
|
||||
protected internal RtfHeaderFooter(RtfDocument doc, RtfHeaderFooter headerFooter, int displayAt) : base(new Phrase(""), false) {
|
||||
this.document = doc;
|
||||
this.content = headerFooter.GetContent();
|
||||
this.displayAt = displayAt;
|
||||
for (int i = 0; i < this.content.Length; i++) {
|
||||
if (this.content[i] is IElement) {
|
||||
try {
|
||||
this.content[i] = this.document.GetMapper().MapElement((IElement) this.content[i])[0];
|
||||
} catch (DocumentException) {
|
||||
}
|
||||
}
|
||||
if (this.content[i] is IRtfBasicElement) {
|
||||
((IRtfBasicElement) this.content[i]).SetInHeader(true);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs a RtfHeaderFooter for a HeaderFooter.
|
||||
*
|
||||
* @param doc The RtfDocument this RtfHeaderFooter belongs to
|
||||
* @param headerFooter The HeaderFooter to base this RtfHeaderFooter on
|
||||
*/
|
||||
protected internal RtfHeaderFooter(RtfDocument doc, HeaderFooter headerFooter) : base(new Phrase(""), false) {
|
||||
this.document = doc;
|
||||
Paragraph par = new Paragraph();
|
||||
par.Alignment = headerFooter.Alignment;
|
||||
if (headerFooter.Before != null) {
|
||||
par.Add(headerFooter.Before);
|
||||
}
|
||||
if (headerFooter.IsNumbered()) {
|
||||
par.Add(new FD.RtfPageNumber(this.document));
|
||||
}
|
||||
if (headerFooter.After != null) {
|
||||
par.Add(headerFooter.After);
|
||||
}
|
||||
try {
|
||||
this.content = new Object[1];
|
||||
this.content[0] = doc.GetMapper().MapElement(par)[0];
|
||||
((IRtfBasicElement) this.content[0]).SetInHeader(true);
|
||||
} catch (DocumentException) {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs a RtfHeaderFooter for any Element.
|
||||
*
|
||||
* @param element The Element to display as content of this RtfHeaderFooter
|
||||
*/
|
||||
public RtfHeaderFooter(IElement element) : this(new IElement[]{element}) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs a RtfHeaderFooter for an array of Elements.
|
||||
*
|
||||
* @param elements The Elements to display as the content of this RtfHeaderFooter.
|
||||
*/
|
||||
public RtfHeaderFooter(IElement[] elements) : base(new Phrase(""), false){
|
||||
this.content = new Object[elements.Length];
|
||||
for (int i = 0; i < elements.Length; i++) {
|
||||
this.content[i] = elements[i];
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the RtfDocument this RtfElement belongs to
|
||||
*
|
||||
* @param doc The RtfDocument to use
|
||||
*/
|
||||
public void SetRtfDocument(RtfDocument doc) {
|
||||
this.document = doc;
|
||||
if (this.document != null) {
|
||||
for (int i = 0; i < this.content.Length; i++) {
|
||||
try {
|
||||
if (this.content[i] is Element) {
|
||||
this.content[i] = this.document.GetMapper().MapElement((IElement) this.content[i])[0];
|
||||
((IRtfBasicElement) this.content[i]).SetInHeader(true);
|
||||
} else if (this.content[i] is IRtfBasicElement){
|
||||
((IRtfBasicElement) this.content[i]).SetRtfDocument(this.document);
|
||||
((IRtfBasicElement) this.content[i]).SetInHeader(true);
|
||||
}
|
||||
} catch (DocumentException) {
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Write the content of this RtfHeaderFooter.
|
||||
*/
|
||||
public virtual void WriteContent(Stream result) {
|
||||
result.Write(RtfElement.OPEN_GROUP, 0, RtfElement.OPEN_GROUP.Length);
|
||||
if (this.type == TYPE_HEADER) {
|
||||
if (this.displayAt == DISPLAY_ALL_PAGES) {
|
||||
result.Write(HEADER_ALL, 0, HEADER_ALL.Length);
|
||||
} else if (this.displayAt == DISPLAY_FIRST_PAGE) {
|
||||
result.Write(HEADER_FIRST, 0, HEADER_FIRST.Length);
|
||||
} else if (this.displayAt == DISPLAY_LEFT_PAGES) {
|
||||
result.Write(HEADER_LEFT, 0, HEADER_LEFT.Length);
|
||||
} else if (this.displayAt == DISPLAY_RIGHT_PAGES) {
|
||||
result.Write(HEADER_RIGHT, 0, HEADER_RIGHT.Length);
|
||||
}
|
||||
} else {
|
||||
if (this.displayAt == DISPLAY_ALL_PAGES) {
|
||||
result.Write(FOOTER_ALL, 0, FOOTER_ALL.Length);
|
||||
} else if (this.displayAt == DISPLAY_FIRST_PAGE) {
|
||||
result.Write(FOOTER_FIRST, 0, FOOTER_FIRST.Length);
|
||||
} else if (this.displayAt == DISPLAY_LEFT_PAGES) {
|
||||
result.Write(FOOTER_LEFT, 0, FOOTER_LEFT.Length);
|
||||
} else if (this.displayAt == DISPLAY_RIGHT_PAGES) {
|
||||
result.Write(FOOTER_RIGHT, 0, FOOTER_RIGHT.Length);
|
||||
}
|
||||
}
|
||||
result.Write(RtfElement.DELIMITER, 0, RtfElement.DELIMITER.Length);
|
||||
for (int i = 0; i < this.content.Length; i++) {
|
||||
if (this.content[i] is IRtfBasicElement) {
|
||||
IRtfBasicElement rbe = (IRtfBasicElement)this.content[i];
|
||||
rbe.WriteContent(result);
|
||||
}
|
||||
}
|
||||
result.Write(RtfElement.CLOSE_GROUP, 0, RtfElement.CLOSE_GROUP.Length);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Sets the display location of this RtfHeaderFooter
|
||||
*
|
||||
* @param displayAt The display location to use.
|
||||
*/
|
||||
public void SetDisplayAt(int displayAt) {
|
||||
this.displayAt = displayAt;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the type of this RtfHeaderFooter
|
||||
*
|
||||
* @param type The type to use.
|
||||
*/
|
||||
public void SetType(int type) {
|
||||
this.type = type;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the content of this RtfHeaderFooter
|
||||
*
|
||||
* @return The content of this RtfHeaderFooter
|
||||
*/
|
||||
private Object[] GetContent() {
|
||||
return this.content;
|
||||
}
|
||||
|
||||
/**
|
||||
* Unused
|
||||
* @param inTable
|
||||
*/
|
||||
public void SetInTable(bool inTable) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Unused
|
||||
* @param inHeader
|
||||
*/
|
||||
public void SetInHeader(bool inHeader) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the alignment of this RtfHeaderFooter. Passes the setting
|
||||
* on to the contained element.
|
||||
*/
|
||||
public void SetAlignment(int alignment) {
|
||||
base.Alignment = alignment;
|
||||
for (int i = 0; i < this.content.Length; i++) {
|
||||
if (this.content[i] is Paragraph) {
|
||||
((Paragraph) this.content[i]).Alignment = alignment;
|
||||
} else if (this.content[i] is Table) {
|
||||
((Table) this.content[i]).Alignment = alignment;
|
||||
} else if (this.content[i] is Image) {
|
||||
((Image) this.content[i]).Alignment = alignment;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
@@ -0,0 +1,377 @@
|
||||
using System;
|
||||
using System.IO;
|
||||
using iTextSharp.text;
|
||||
using iTextSharp.text.rtf;
|
||||
using iTextSharp.text.rtf.document;
|
||||
/*
|
||||
* Created on Aug 6, 2004
|
||||
*
|
||||
* To change the template for this generated file go to
|
||||
* Window - Preferences - Java - Code Generation - Code and Comments
|
||||
*/
|
||||
namespace iTextSharp.text.rtf.headerfooter {
|
||||
|
||||
/**
|
||||
* The RtfHeaderFooterGroup holds 0 - 3 RtfHeaderFooters that create a group
|
||||
* of headers or footers.
|
||||
*
|
||||
* @version $Version:$
|
||||
* @author Mark Hall (Mark.Hall@mail.room3b.eu)
|
||||
*/
|
||||
public class RtfHeaderFooterGroup : HeaderFooter, IRtfBasicElement {
|
||||
|
||||
/**
|
||||
* This RtfHeaderFooterGroup contains no RtfHeaderFooter objects
|
||||
*/
|
||||
private const int MODE_NONE = 0;
|
||||
/**
|
||||
* This RtfHeaderFooterGroup contains one RtfHeaderFooter object
|
||||
*/
|
||||
private const int MODE_SINGLE = 1;
|
||||
/**
|
||||
* This RtfHeaderFooterGroup contains two or three RtfHeaderFooter objects
|
||||
*/
|
||||
private const int MODE_MULTIPLE = 2;
|
||||
|
||||
/**
|
||||
* The current mode of this RtfHeaderFooterGroup. Defaults to MODE_NONE
|
||||
*/
|
||||
private int mode = MODE_NONE;
|
||||
/**
|
||||
* The current type of this RtfHeaderFooterGroup. Defaults to RtfHeaderFooter.TYPE_HEADER
|
||||
*/
|
||||
private int type = RtfHeaderFooter.TYPE_HEADER;
|
||||
|
||||
/**
|
||||
* The RtfHeaderFooter for all pages
|
||||
*/
|
||||
private RtfHeaderFooter headerAll = null;
|
||||
/**
|
||||
* The RtfHeaderFooter for the first page
|
||||
*/
|
||||
private RtfHeaderFooter headerFirst = null;
|
||||
/**
|
||||
* The RtfHeaderFooter for the left hand pages
|
||||
*/
|
||||
private RtfHeaderFooter headerLeft = null;
|
||||
/**
|
||||
* The RtfHeaderFooter for the right hand pages
|
||||
*/
|
||||
private RtfHeaderFooter headerRight = null;
|
||||
/**
|
||||
* The RtfDocument this RtfHeaderFooterGroup belongs to
|
||||
*/
|
||||
private RtfDocument document = null;
|
||||
|
||||
/**
|
||||
* Constructs a RtfHeaderGroup to which you add headers/footers using
|
||||
* via the setHeaderFooter method.
|
||||
*
|
||||
*/
|
||||
public RtfHeaderFooterGroup() : base(new Phrase(""), false) {
|
||||
this.mode = MODE_NONE;
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs a certain type of RtfHeaderFooterGroup. RtfHeaderFooter.TYPE_HEADER
|
||||
* and RtfHeaderFooter.TYPE_FOOTER are valid values for type.
|
||||
*
|
||||
* @param doc The RtfDocument this RtfHeaderFooter belongs to
|
||||
* @param type The type of RtfHeaderFooterGroup to create
|
||||
*/
|
||||
public RtfHeaderFooterGroup(RtfDocument doc, int type) : base(new Phrase(""), false) {
|
||||
this.document = doc;
|
||||
this.type = type;
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs a RtfHeaderFooterGroup by copying the content of the original
|
||||
* RtfHeaderFooterGroup
|
||||
*
|
||||
* @param doc The RtfDocument this RtfHeaderFooter belongs to
|
||||
* @param headerFooter The RtfHeaderFooterGroup to copy
|
||||
* @param type The type of RtfHeaderFooterGroup to create
|
||||
*/
|
||||
public RtfHeaderFooterGroup(RtfDocument doc, RtfHeaderFooterGroup headerFooter, int type) : base(new Phrase(""), false) {
|
||||
this.document = doc;
|
||||
this.mode = headerFooter.GetMode();
|
||||
this.type = type;
|
||||
if (headerFooter.GetHeaderAll() != null) {
|
||||
this.headerAll = new RtfHeaderFooter(this.document, headerFooter.GetHeaderAll(), RtfHeaderFooter.DISPLAY_ALL_PAGES);
|
||||
}
|
||||
if (headerFooter.GetHeaderFirst() != null) {
|
||||
this.headerFirst = new RtfHeaderFooter(this.document, headerFooter.GetHeaderFirst(), RtfHeaderFooter.DISPLAY_FIRST_PAGE);
|
||||
}
|
||||
if (headerFooter.GetHeaderLeft() != null) {
|
||||
this.headerLeft = new RtfHeaderFooter(this.document, headerFooter.GetHeaderLeft(), RtfHeaderFooter.DISPLAY_LEFT_PAGES);
|
||||
}
|
||||
if (headerFooter.GetHeaderRight() != null) {
|
||||
this.headerRight = new RtfHeaderFooter(this.document, headerFooter.GetHeaderRight(), RtfHeaderFooter.DISPLAY_RIGHT_PAGES);
|
||||
}
|
||||
SetType(this.type);
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs a RtfHeaderFooterGroup for a certain RtfHeaderFooter.
|
||||
*
|
||||
* @param doc The RtfDocument this RtfHeaderFooter belongs to
|
||||
* @param headerFooter The RtfHeaderFooter to display
|
||||
* @param type The typ of RtfHeaderFooterGroup to create
|
||||
*/
|
||||
public RtfHeaderFooterGroup(RtfDocument doc, RtfHeaderFooter headerFooter, int type) : base(new Phrase(""), false) {
|
||||
this.document = doc;
|
||||
this.type = type;
|
||||
this.mode = MODE_SINGLE;
|
||||
headerAll = new RtfHeaderFooter(doc, headerFooter, RtfHeaderFooter.DISPLAY_ALL_PAGES);
|
||||
headerAll.SetType(this.type);
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs a RtfHeaderGroup for a certain HeaderFooter
|
||||
*
|
||||
* @param doc The RtfDocument this RtfHeaderFooter belongs to
|
||||
* @param headerFooter The HeaderFooter to display
|
||||
* @param type The typ of RtfHeaderFooterGroup to create
|
||||
*/
|
||||
public RtfHeaderFooterGroup(RtfDocument doc, HeaderFooter headerFooter, int type) : base(new Phrase(""), false) {
|
||||
this.document = doc;
|
||||
this.type = type;
|
||||
this.mode = MODE_SINGLE;
|
||||
headerAll = new RtfHeaderFooter(doc, headerFooter, type, RtfHeaderFooter.DISPLAY_ALL_PAGES);
|
||||
headerAll.SetType(this.type);
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the RtfDocument this RtfElement belongs to
|
||||
*
|
||||
* @param doc The RtfDocument to use
|
||||
*/
|
||||
public void SetRtfDocument(RtfDocument doc) {
|
||||
this.document = doc;
|
||||
if (headerAll != null) {
|
||||
headerAll.SetRtfDocument(this.document);
|
||||
}
|
||||
if (headerFirst != null) {
|
||||
headerFirst.SetRtfDocument(this.document);
|
||||
}
|
||||
if (headerLeft != null) {
|
||||
headerLeft.SetRtfDocument(this.document);
|
||||
}
|
||||
if (headerRight != null) {
|
||||
headerRight.SetRtfDocument(this.document);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Write the content of this RtfHeaderFooterGroup.
|
||||
*/
|
||||
public virtual void WriteContent(Stream result) {
|
||||
if (this.mode == MODE_SINGLE) {
|
||||
headerAll.WriteContent(result);
|
||||
} else if (this.mode == MODE_MULTIPLE) {
|
||||
if (headerFirst != null) {
|
||||
headerFirst.WriteContent(result);
|
||||
}
|
||||
if (headerLeft != null) {
|
||||
headerLeft.WriteContent(result);
|
||||
}
|
||||
if (headerRight != null) {
|
||||
headerRight.WriteContent(result);
|
||||
}
|
||||
if (headerAll != null) {
|
||||
headerAll.WriteContent(result);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Set a RtfHeaderFooter to be displayed at a certain position
|
||||
*
|
||||
* @param headerFooter The RtfHeaderFooter to display
|
||||
* @param displayAt The display location to use
|
||||
*/
|
||||
public void SetHeaderFooter(RtfHeaderFooter headerFooter, int displayAt) {
|
||||
this.mode = MODE_MULTIPLE;
|
||||
headerFooter.SetRtfDocument(this.document);
|
||||
headerFooter.SetType(this.type);
|
||||
headerFooter.SetDisplayAt(displayAt);
|
||||
switch (displayAt) {
|
||||
case RtfHeaderFooter.DISPLAY_ALL_PAGES:
|
||||
headerAll = headerFooter;
|
||||
break;
|
||||
case RtfHeaderFooter.DISPLAY_FIRST_PAGE:
|
||||
headerFirst = headerFooter;
|
||||
break;
|
||||
case RtfHeaderFooter.DISPLAY_LEFT_PAGES:
|
||||
headerLeft = headerFooter;
|
||||
break;
|
||||
case RtfHeaderFooter.DISPLAY_RIGHT_PAGES:
|
||||
headerRight = headerFooter;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Set a HeaderFooter to be displayed at a certain position
|
||||
*
|
||||
* @param headerFooter The HeaderFooter to set
|
||||
* @param displayAt The display location to use
|
||||
*/
|
||||
public void SetHeaderFooter(HeaderFooter headerFooter, int displayAt) {
|
||||
this.mode = MODE_MULTIPLE;
|
||||
switch (displayAt) {
|
||||
case RtfHeaderFooter.DISPLAY_ALL_PAGES:
|
||||
headerAll = new RtfHeaderFooter(this.document, headerFooter, this.type, displayAt);
|
||||
break;
|
||||
case RtfHeaderFooter.DISPLAY_FIRST_PAGE:
|
||||
headerFirst = new RtfHeaderFooter(this.document, headerFooter, this.type, displayAt);
|
||||
break;
|
||||
case RtfHeaderFooter.DISPLAY_LEFT_PAGES:
|
||||
headerLeft = new RtfHeaderFooter(this.document, headerFooter, this.type, displayAt);
|
||||
break;
|
||||
case RtfHeaderFooter.DISPLAY_RIGHT_PAGES:
|
||||
headerRight = new RtfHeaderFooter(this.document, headerFooter, this.type, displayAt);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Set that this RtfHeaderFooterGroup should have a title page. If only
|
||||
* a header / footer for all pages exists, then it will be copied to the
|
||||
* first page aswell.
|
||||
*/
|
||||
public void SetHasTitlePage() {
|
||||
if (this.mode == MODE_SINGLE) {
|
||||
this.mode = MODE_MULTIPLE;
|
||||
headerFirst = new RtfHeaderFooter(this.document, headerAll, RtfHeaderFooter.DISPLAY_FIRST_PAGE);
|
||||
headerFirst.SetType(this.type);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Set that this RtfHeaderFooterGroup should have facing pages. If only
|
||||
* a header / footer for all pages exists, then it will be copied to the left
|
||||
* and right pages aswell.
|
||||
*/
|
||||
public void SetHasFacingPages() {
|
||||
if (this.mode == MODE_SINGLE) {
|
||||
this.mode = MODE_MULTIPLE;
|
||||
this.headerLeft = new RtfHeaderFooter(this.document, this.headerAll, RtfHeaderFooter.DISPLAY_LEFT_PAGES);
|
||||
this.headerLeft.SetType(this.type);
|
||||
this.headerRight = new RtfHeaderFooter(this.document, this.headerAll, RtfHeaderFooter.DISPLAY_RIGHT_PAGES);
|
||||
this.headerRight.SetType(this.type);
|
||||
this.headerAll = null;
|
||||
} else if (this.mode == MODE_MULTIPLE) {
|
||||
if (this.headerLeft == null && this.headerAll != null) {
|
||||
this.headerLeft = new RtfHeaderFooter(this.document, this.headerAll, RtfHeaderFooter.DISPLAY_LEFT_PAGES);
|
||||
this.headerLeft.SetType(this.type);
|
||||
}
|
||||
if (this.headerRight == null && this.headerAll != null) {
|
||||
this.headerRight = new RtfHeaderFooter(this.document, this.headerAll, RtfHeaderFooter.DISPLAY_RIGHT_PAGES);
|
||||
this.headerRight.SetType(this.type);
|
||||
}
|
||||
this.headerAll = null;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Get whether this RtfHeaderFooterGroup has a titlepage
|
||||
*
|
||||
* @return Whether this RtfHeaderFooterGroup has a titlepage
|
||||
*/
|
||||
public bool HasTitlePage() {
|
||||
return (headerFirst != null);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get whether this RtfHeaderFooterGroup has facing pages
|
||||
*
|
||||
* @return Whether this RtfHeaderFooterGroup has facing pages
|
||||
*/
|
||||
public bool HasFacingPages() {
|
||||
return (headerLeft != null || headerRight != null);
|
||||
}
|
||||
|
||||
/**
|
||||
* Unused
|
||||
* @param inTable
|
||||
*/
|
||||
public void SetInTable(bool inTable) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Unused
|
||||
* @param inHeader
|
||||
*/
|
||||
public void SetInHeader(bool inHeader) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the type of this RtfHeaderFooterGroup. RtfHeaderFooter.TYPE_HEADER
|
||||
* or RtfHeaderFooter.TYPE_FOOTER. Also sets the type for all RtfHeaderFooters
|
||||
* of this RtfHeaderFooterGroup.
|
||||
*
|
||||
* @param type The type to use
|
||||
*/
|
||||
public void SetType(int type) {
|
||||
this.type = type;
|
||||
if (headerAll != null) {
|
||||
headerAll.SetType(this.type);
|
||||
}
|
||||
if (headerFirst != null) {
|
||||
headerFirst.SetType(this.type);
|
||||
}
|
||||
if (headerLeft != null) {
|
||||
headerLeft.SetType(this.type);
|
||||
}
|
||||
if (headerRight != null) {
|
||||
headerRight.SetType(this.type);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the mode of this RtfHeaderFooterGroup
|
||||
*
|
||||
* @return The mode of this RtfHeaderFooterGroup
|
||||
*/
|
||||
protected int GetMode() {
|
||||
return this.mode;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the RtfHeaderFooter for all pages
|
||||
*
|
||||
* @return The RtfHeaderFooter for all pages
|
||||
*/
|
||||
protected RtfHeaderFooter GetHeaderAll() {
|
||||
return headerAll;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the RtfHeaderFooter for the title page
|
||||
*
|
||||
* @return The RtfHeaderFooter for the title page
|
||||
*/
|
||||
protected RtfHeaderFooter GetHeaderFirst() {
|
||||
return headerFirst;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the RtfHeaderFooter for all left hand pages
|
||||
*
|
||||
* @return The RtfHeaderFooter for all left hand pages
|
||||
*/
|
||||
protected RtfHeaderFooter GetHeaderLeft() {
|
||||
return headerLeft;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the RtfHeaderFooter for all right hand pages
|
||||
*
|
||||
* @return The RtfHeaderFooter for all right hand pages
|
||||
*/
|
||||
protected RtfHeaderFooter GetHeaderRight() {
|
||||
return headerRight;
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user