diff options
Diffstat (limited to 'src/contrib')
-rw-r--r-- | src/contrib/src/org/apache/poi/hssf/contrib/view/SVBorder.java | 94 | ||||
-rw-r--r-- | src/contrib/src/org/apache/poi/hssf/contrib/view/SVTableCellRenderer.java | 54 |
2 files changed, 145 insertions, 3 deletions
diff --git a/src/contrib/src/org/apache/poi/hssf/contrib/view/SVBorder.java b/src/contrib/src/org/apache/poi/hssf/contrib/view/SVBorder.java new file mode 100644 index 0000000000..5522c72f5e --- /dev/null +++ b/src/contrib/src/org/apache/poi/hssf/contrib/view/SVBorder.java @@ -0,0 +1,94 @@ +package org.apache.poi.hssf.contrib.view; + +import java.awt.Graphics; +import java.awt.Insets; +import java.awt.Rectangle; +import java.awt.Color; +import java.awt.Component; + +import javax.swing.border.AbstractBorder; + +/** + * This is an attempt to implement Excel style borders for the SuckyViewer + * + */ +public class SVBorder extends AbstractBorder { + Color northColor = null; + Color eastColor = null; + Color southColor = null; + Color westColor = null; + int northThickness; + int eastThickness; + int southThickness; + int westThickness; + boolean northBorder=false; + boolean eastBorder=false; + boolean southBorder=false; + boolean westBorder=false; + + public SVBorder(Color northColor, Color eastColor, + Color southColor, Color westColor, + int northThickness, int eastThickness, + int southThickness, int westThickness, + boolean northBorder, boolean eastBorder, + boolean southBorder, boolean westBorder) { + this.northColor = northColor; + this.eastColor = eastColor; + this.southColor = southColor; + this.westColor = westColor; + this.northThickness = northThickness; + this.eastThickness = eastThickness; + this.southThickness = southThickness; + this.westThickness = westThickness; + this.northBorder=northBorder; + this.eastBorder=eastBorder; + this.southBorder=southBorder; + this.westBorder=westBorder; + } + + public void paintBorder(Component c, Graphics g, int x, int y, int width, + int height) { + Color oldColor = g.getColor(); + int i; + + if (northBorder) { + System.out.println("NorthBorder x="+x+",y="+y+"x1="+width+"y1="+y); + g.setColor(northColor); + + for (int k=0; k < northThickness; k++) { + g.drawLine(x,y+k,width,y+k); + } + } + + + if (eastBorder) { + System.out.println("EastBorder x="+x+",y="+y+"x1="+width+"y1="+y); + g.setColor(eastColor); + + for (int k=0; k < eastThickness; k++) { + g.drawLine(width-k,y,width-k,height); + } + } + + if (southBorder) { + System.out.println("SouthBorder x="+x+",y="+height+"x1="+width+"y1="+height); + g.setColor(southColor); + for (int k=0; k < southThickness; k++) { + g.drawLine(x,height - k,width,height - k); + } + } + + if (westBorder) { + System.out.println("WestBorder x="+x+",y="+y+"x1="+width+"y1="+y); + g.setColor(westColor); + + for (int k=0; k < westThickness; k++) { + g.drawLine(x+k,y,x+k,height); + } + } + + g.setColor(oldColor); + } + + +} diff --git a/src/contrib/src/org/apache/poi/hssf/contrib/view/SVTableCellRenderer.java b/src/contrib/src/org/apache/poi/hssf/contrib/view/SVTableCellRenderer.java index 0c45069305..20a25010e9 100644 --- a/src/contrib/src/org/apache/poi/hssf/contrib/view/SVTableCellRenderer.java +++ b/src/contrib/src/org/apache/poi/hssf/contrib/view/SVTableCellRenderer.java @@ -123,6 +123,8 @@ public class SVTableCellRenderer extends JLabel public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column) { + boolean isBorderSet = false; + if (isSelected) { super.setForeground(table.getSelectionForeground()); super.setBackground(table.getSelectionBackground()); @@ -134,13 +136,19 @@ public class SVTableCellRenderer extends JLabel HSSFFont f = wb.getFontAt(s.getFontIndex()); boolean isbold = f.getBoldweight() > HSSFFont.BOLDWEIGHT_NORMAL; boolean isitalics = f.getItalic(); +// System.out.println("bold="+isbold); +// System.out.println("italics="+isitalics); int fontstyle = 0; if (isbold) fontstyle = Font.BOLD; if (isitalics) fontstyle = fontstyle | Font.ITALIC; + int fontheight = f.getFontHeightInPoints(); + if (fontheight == 9) fontheight = 10; //fix for stupid ol Windows + +// System.out.println("fontsizeinpnts="+f.getFontHeightInPoints()); - Font font = new Font(f.getFontName(),fontstyle,f.getFontHeightInPoints()); + Font font = new Font(f.getFontName(),fontstyle,fontheight); setFont(font); @@ -160,16 +168,56 @@ public class SVTableCellRenderer extends JLabel rgb = clr.getTriplet(); awtcolor = new Color(rgb[0],rgb[1],rgb[2]); setForeground(awtcolor); + + if (s.getBorderBottom() != HSSFCellStyle.BORDER_NONE || + s.getBorderTop() != HSSFCellStyle.BORDER_NONE || + s.getBorderLeft() != HSSFCellStyle.BORDER_NONE || + s.getBorderRight() != HSSFCellStyle.BORDER_NONE) { + int borderTop = 0; + int borderRight = 0; + int borderBottom = 0; + int borderLeft = 0; + + if(s.getBorderBottom() != HSSFCellStyle.BORDER_NONE) { + borderBottom = 2; + } + + if(s.getBorderRight() != HSSFCellStyle.BORDER_NONE) { + borderRight = 2; + } + + if(s.getBorderTop() != HSSFCellStyle.BORDER_NONE) { + borderTop = 2; + } + + if(s.getBorderLeft() != HSSFCellStyle.BORDER_NONE) { + borderLeft = 2; + } + + SVBorder border = new SVBorder(Color.black, Color.black, + Color.black, Color.black, + borderTop, borderRight, + borderBottom, borderLeft, + s.getBorderTop() != HSSFCellStyle.BORDER_NONE, + s.getBorderRight() != HSSFCellStyle.BORDER_NONE, + s.getBorderBottom() != HSSFCellStyle.BORDER_NONE, + s.getBorderLeft() != HSSFCellStyle.BORDER_NONE); + setBorder(border); + isBorderSet=true; + //need custom border that can have north,east,south,west settings + } } if (hasFocus) { - setBorder( UIManager.getBorder("Table.focusCellHighlightBorder") ); + if (!isBorderSet) { + setBorder( UIManager.getBorder("Table.focusCellHighlightBorder") ); + } if (table.isCellEditable(row, column)) { super.setForeground( UIManager.getColor("Table.focusCellForeground") ); super.setBackground( UIManager.getColor("Table.focusCellBackground") ); } - } else { + } else if (!isBorderSet) { setBorder(noFocusBorder); } |