Added column count
This commit is contained in:
parent
aee06864b8
commit
5bb29b8b6c
5 changed files with 56 additions and 23 deletions
|
@ -138,8 +138,8 @@ public class StyleWithProperties extends OfficeStyle {
|
||||||
backgroundImageProperties.loadFromDOM(child);
|
backgroundImageProperties.loadFromDOM(child);
|
||||||
}
|
}
|
||||||
else if (XMLString.STYLE_COLUMNS.equals(sName)) {
|
else if (XMLString.STYLE_COLUMNS.equals(sName)) {
|
||||||
nColCount = Misc.getPosInteger(Misc.getAttribute(child,
|
nColCount = Misc.getPosInteger(Misc.getAttribute(child, XMLString.FO_COLUMN_COUNT),1);
|
||||||
XMLString.FO_COLUMN_COUNT),1);
|
|
||||||
// TODO: read individual columns
|
// TODO: read individual columns
|
||||||
}
|
}
|
||||||
else if (XMLString.STYLE_FOOTNOTE_SEP.equals(sName)) {
|
else if (XMLString.STYLE_FOOTNOTE_SEP.equals(sName)) {
|
||||||
|
|
|
@ -321,7 +321,7 @@ public class DocumentSeparator {
|
||||||
Element container = converter.createElement("div");
|
Element container = converter.createElement("div");
|
||||||
container.setAttribute("class", "pageContainer");
|
container.setAttribute("class", "pageContainer");
|
||||||
if (pageContainerStyle != null) {
|
if (pageContainerStyle != null) {
|
||||||
System.out.println(pageContainerStyle);
|
//System.out.println(pageContainerStyle);
|
||||||
container.setAttribute("style", pageContainerStyle);
|
container.setAttribute("style", pageContainerStyle);
|
||||||
}
|
}
|
||||||
hnode.appendChild(container);
|
hnode.appendChild(container);
|
||||||
|
@ -345,5 +345,9 @@ public class DocumentSeparator {
|
||||||
return comment;
|
return comment;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getPageContainerStyle() {
|
||||||
|
return this.pageContainerStyle;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -133,9 +133,16 @@ public class FrameStyleConverter extends StyleWithPropertiesConverterHelper {
|
||||||
cssBorder(style,props,bInherit);
|
cssBorder(style,props,bInherit);
|
||||||
cssPadding(style,props,bInherit);
|
cssPadding(style,props,bInherit);
|
||||||
cssBackground(style,props,bInherit);
|
cssBackground(style,props,bInherit);
|
||||||
}
|
cssColumns(style,props,bInherit);
|
||||||
|
}
|
||||||
|
|
||||||
public void cssMargins(StyleWithProperties style, CSVList props, boolean bInherit){
|
private void cssColumns(StyleWithProperties style, CSVList props, boolean bInherit) {
|
||||||
|
String columnCount = style.getAbsoluteProperty(XMLString.FO_COLUMN_COUNT);
|
||||||
|
System.out.println("columnCount " + columnCount);
|
||||||
|
//System.out.println(style.);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void cssMargins(StyleWithProperties style, CSVList props, boolean bInherit){
|
||||||
// *Absolute* values fit with css
|
// *Absolute* values fit with css
|
||||||
String s;
|
String s;
|
||||||
if (bInherit || style.getProperty(XMLString.FO_MARGIN_LEFT,false)!=null) {
|
if (bInherit || style.getProperty(XMLString.FO_MARGIN_LEFT,false)!=null) {
|
||||||
|
|
|
@ -93,7 +93,10 @@ class NoteConverter extends ConverterHelper {
|
||||||
noteList = new ArrayList<Node>();
|
noteList = new ArrayList<Node>();
|
||||||
notes.put(section, noteList);
|
notes.put(section, noteList);
|
||||||
}
|
}
|
||||||
noteList.add(onode);
|
|
||||||
|
noteList.add(onode);
|
||||||
|
System.out.println("add note to section " + section + " notelist size is " + noteList.size());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean hasNotes() {
|
boolean hasNotes() {
|
||||||
|
@ -133,6 +136,15 @@ class NoteConverter extends ConverterHelper {
|
||||||
|
|
||||||
public void flushNotes(Node hnode, String sEpubType, String section) {
|
public void flushNotes(Node hnode, String sEpubType, String section) {
|
||||||
List<Node> noteList = notes.get(section);
|
List<Node> noteList = notes.get(section);
|
||||||
|
if (noteList == null) {
|
||||||
|
//System.out.println("noteList is null");
|
||||||
|
//System.out.println("notes " + notes.size());
|
||||||
|
/*for (StackTraceElement ste : Thread.currentThread().getStackTrace()) {
|
||||||
|
System.out.println(ste);
|
||||||
|
}*/
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
int nSize = noteList.size();
|
int nSize = noteList.size();
|
||||||
for (int i=0; i<nSize; i++) {
|
for (int i=0; i<nSize; i++) {
|
||||||
Node note = noteList.get(i);
|
Node note = noteList.get(i);
|
||||||
|
|
|
@ -32,6 +32,7 @@ import org.w3c.dom.Node;
|
||||||
import org.w3c.dom.NodeList;
|
import org.w3c.dom.NodeList;
|
||||||
import org.w3c.dom.Element;
|
import org.w3c.dom.Element;
|
||||||
|
|
||||||
|
import writer2latex.util.CSVList;
|
||||||
import writer2latex.util.Misc;
|
import writer2latex.util.Misc;
|
||||||
import writer2latex.office.FontDeclaration;
|
import writer2latex.office.FontDeclaration;
|
||||||
import writer2latex.office.MasterPage;
|
import writer2latex.office.MasterPage;
|
||||||
|
@ -547,29 +548,38 @@ public class TextConverter extends ConverterHelper {
|
||||||
/* Process a text:section tag (returns current html node) */
|
/* Process a text:section tag (returns current html node) */
|
||||||
private Node handleSection(Node onode, Node hnode) {
|
private Node handleSection(Node onode, Node hnode) {
|
||||||
// Unlike headings, paragraphs and spans, text:display is not attached to the style:
|
// Unlike headings, paragraphs and spans, text:display is not attached to the style:
|
||||||
Node result = null;
|
String lastSection = currentSection;
|
||||||
|
String sectionName = Misc.getAttribute(onode,TEXT_NAME);
|
||||||
|
|
||||||
|
String savedStyle = docSep.getPageContainerStyle();
|
||||||
if (!bDisplayHiddenText && "none".equals(Misc.getAttribute(onode,TEXT_DISPLAY))) { return hnode; }
|
if (!bDisplayHiddenText && "none".equals(Misc.getAttribute(onode,TEXT_DISPLAY))) { return hnode; }
|
||||||
hnode = docSep.closePage(hnode);
|
hnode = docSep.closePage(hnode);
|
||||||
|
currentSection = sectionName;
|
||||||
String sectionName = Misc.getAttribute(onode,TEXT_NAME);
|
setSectionStyle(onode);
|
||||||
String sStyleName = Misc.getAttribute(onode,TEXT_STYLE_NAME);
|
|
||||||
StyleInfo sectionInfo = new StyleInfo();
|
|
||||||
getSectionSc().applyStyle(sStyleName, sectionInfo);
|
|
||||||
docSep.setPageContainerStyle(sectionInfo.props.toString());
|
|
||||||
hnode = docSep.openPage(hnode, pageNum);
|
hnode = docSep.openPage(hnode, pageNum);
|
||||||
/* hnode.appendChild(div);
|
|
||||||
converter.addTarget(div, sectionName + "|region");
|
|
||||||
applyStyle(sectionInfo, div);
|
|
||||||
sections.push(onode);
|
|
||||||
*/
|
|
||||||
|
|
||||||
hnode = traverseBlockText(onode, hnode);
|
hnode = traverseBlockText(onode, hnode);
|
||||||
|
System.out.println("sectionname " + sectionName);
|
||||||
/*
|
insertEndnotes((Element) hnode, sectionName);
|
||||||
sections.pop();
|
currentSection = lastSection;
|
||||||
*/
|
docSep.setPageContainerStyle(savedStyle);
|
||||||
|
|
||||||
return hnode;
|
return hnode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void setSectionStyle(Node onode) {
|
||||||
|
StyleWithProperties sectionStyle;
|
||||||
|
String sStyleName = Misc.getAttribute(onode,TEXT_STYLE_NAME);
|
||||||
|
OfficeStyle ofStyle = getSectionSc().getStyles().getStyle(sStyleName);
|
||||||
|
if (ofStyle != null) {
|
||||||
|
sectionStyle = (StyleWithProperties) ofStyle;
|
||||||
|
int colCount = sectionStyle.getColCount();
|
||||||
|
if (colCount > 1 ) {
|
||||||
|
String styleValue = "column-count: " + colCount + ";";
|
||||||
|
docSep.setPageContainerStyle(styleValue);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void handleHeading(Element onode, Element hnode, boolean bAfterSplit) {
|
private void handleHeading(Element onode, Element hnode, boolean bAfterSplit) {
|
||||||
int nListLevel = getOutlineLevel((Element)onode);
|
int nListLevel = getOutlineLevel((Element)onode);
|
||||||
|
|
Loading…
Add table
Reference in a new issue