diff options
author | Karen Lease <klease@apache.org> | 2001-03-04 21:39:54 +0000 |
---|---|---|
committer | Karen Lease <klease@apache.org> | 2001-03-04 21:39:54 +0000 |
commit | b1a53796b5d9c6cb17143d7534a84d98f6795aef (patch) | |
tree | dfae8a4ca09d260b1612cdb7bab02e3479a9ad26 | |
parent | bd571c5c746ea6d60acb01a2805347f21473b186 (diff) | |
download | xmlgraphics-fop-b1a53796b5d9c6cb17143d7534a84d98f6795aef.tar.gz xmlgraphics-fop-b1a53796b5d9c6cb17143d7534a84d98f6795aef.zip |
Use new HyphenationProps class
git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@194128 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r-- | src/org/apache/fop/layout/BlockArea.java | 31 | ||||
-rw-r--r-- | src/org/apache/fop/layout/LineArea.java | 34 |
2 files changed, 17 insertions, 48 deletions
diff --git a/src/org/apache/fop/layout/BlockArea.java b/src/org/apache/fop/layout/BlockArea.java index 94ee4bc50..6fc8ea561 100644 --- a/src/org/apache/fop/layout/BlockArea.java +++ b/src/org/apache/fop/layout/BlockArea.java @@ -99,12 +99,7 @@ public class BlockArea extends Area { protected boolean hasLines = false; /*hyphenation*/ - protected int hyphenate; - protected char hyphenationChar; - protected int hyphenationPushCharacterCount; - protected int hyphenationRemainCharacterCount; - protected String language; - protected String country; + protected HyphenationProps hyphProps; protected Vector pendingFootnotes = null; @@ -174,9 +169,7 @@ public class BlockArea extends Area { if (currentHeight + this.currentLineArea.getHeight() > maxHeight) { return null; } - this.currentLineArea.changeHyphenation(language, country, - hyphenate, hyphenationChar, hyphenationPushCharacterCount, - hyphenationRemainCharacterCount); + this.currentLineArea.changeHyphenation(hyphProps); this.hasLines = true; return this.currentLineArea; } @@ -199,9 +192,7 @@ public class BlockArea extends Area { this.currentLineArea = new LineArea(fontState, lineHeight, halfLeading, allocationWidth, startIndent, endIndent, currentLineArea); - this.currentLineArea.changeHyphenation(language, country, - hyphenate, hyphenationChar, hyphenationPushCharacterCount, - hyphenationRemainCharacterCount); + this.currentLineArea.changeHyphenation(hyphProps); if (currentHeight + lineHeight > maxHeight) { return null; } @@ -239,7 +230,8 @@ public class BlockArea extends Area { // KL: I think we should just return startIndent here! public int getStartIndent() { - return startIndent + paddingLeft + borderWidthLeft; + //return startIndent + paddingLeft + borderWidthLeft; + return startIndent ; } public void setIndents(int startIndent, int endIndent) { @@ -257,17 +249,8 @@ public class BlockArea extends Area { return halfLeading; } - public void setHyphenation(String language, String country, - int hyphenate, char hyphenationChar, - int hyphenationPushCharacterCount, - int hyphenationRemainCharacterCount) { - this.language = language; - this.country = country; - this.hyphenate = hyphenate; - this.hyphenationChar = hyphenationChar; - this.hyphenationPushCharacterCount = hyphenationPushCharacterCount; - this.hyphenationRemainCharacterCount = - hyphenationRemainCharacterCount; + public void setHyphenation(HyphenationProps hyphProps) { + this.hyphProps = hyphProps; } public void addFootnote(FootnoteBody fb) { diff --git a/src/org/apache/fop/layout/LineArea.java b/src/org/apache/fop/layout/LineArea.java index 6c308df6e..bbdc6f66f 100644 --- a/src/org/apache/fop/layout/LineArea.java +++ b/src/org/apache/fop/layout/LineArea.java @@ -96,12 +96,7 @@ public class LineArea extends Area { int vAlign; /*hyphenation*/ - protected int hyphenate; - protected char hyphenationChar; - protected int hyphenationPushCharacterCount; - protected int hyphenationRemainCharacterCount; - protected String language; - protected String country; + HyphenationProps hyphProps; /* the width of text that has definitely made it into the line area */ @@ -421,7 +416,7 @@ public class LineArea extends Area { return wordStart; } } else if (this.wrapOption == WrapOption.WRAP) { - if (this.hyphenate == Hyphenate.TRUE) { + if (this.hyphProps.hyphenate == Hyphenate.TRUE) { return this.doHyphenation(data,i,wordStart,this.getContentWidth() - (finalWidth + spaceWidth + pendingWidth)); } else { return wordStart; @@ -781,18 +776,8 @@ public class LineArea extends Area { * and minimum number of character to remain one the previous line and to be on the * next line. */ - public void changeHyphenation(String language, String country, - int hyphenate, char hyphenationChar, - int hyphenationPushCharacterCount, - int hyphenationRemainCharacterCount) { - this.language = language; - this.country = country; - this.hyphenate = hyphenate; - this.hyphenationChar = hyphenationChar; - this.hyphenationPushCharacterCount = hyphenationPushCharacterCount; - this.hyphenationRemainCharacterCount = - hyphenationRemainCharacterCount; - + public void changeHyphenation(HyphenationProps hyphProps) { + this.hyphProps = hyphProps; } @@ -875,7 +860,7 @@ public class LineArea extends Area { */ public int doHyphenation (char [] characters, int position, int wordStart, int remainingWidth) { //check whether the language property has been set - if (this.language.equalsIgnoreCase("none")) { + if (this.hyphProps.language.equalsIgnoreCase("none")) { MessageHandler.errorln("if property 'hyphenate' is used, a language must be specified"); return wordStart; } @@ -896,7 +881,7 @@ public class LineArea extends Area { String wordToHyphenate; //width of hyphenation character - int hyphCharWidth = this.currentFontState.width(currentFontState.mapChar(this.hyphenationChar)); + int hyphCharWidth = this.currentFontState.width(currentFontState.mapChar(this.hyphProps.hyphenationChar)); remainingWidth -= hyphCharWidth; //handles ' or " at the beginning of the word @@ -924,7 +909,8 @@ public class LineArea extends Area { } //are there any hyphenation points - Hyphenation hyph = Hyphenator.hyphenate(language,country,wordToHyphenate,hyphenationRemainCharacterCount,hyphenationPushCharacterCount); + Hyphenation hyph = Hyphenator.hyphenate(hyphProps.language, + hyphProps.country, wordToHyphenate,hyphProps.hyphenationRemainCharacterCount,hyphProps.hyphenationPushCharacterCount); //no hyphenation points and no inword non letter character if (hyph == null && preString == null) { if (remainingString.length() > 0) { @@ -943,7 +929,7 @@ public class LineArea extends Area { int index = getFinalHyphenationPoint(hyph,remainingWidth); if (index != -1) { remainingString.append(hyph.getPreHyphenText(index)); - remainingString.append(this.hyphenationChar); + remainingString.append(this.hyphProps.hyphenationChar); this.addWord(startChar,remainingString); return wordStart + remainingString.length()-1; } @@ -952,7 +938,7 @@ public class LineArea extends Area { int index = getFinalHyphenationPoint(hyph,remainingWidth); if (index != -1) { remainingString.append(preString.append(hyph.getPreHyphenText(index))); - remainingString.append(this.hyphenationChar); + remainingString.append(this.hyphProps.hyphenationChar); this.addWord(startChar,remainingString); return wordStart + remainingString.length()-1; } else { |