Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
net.sf.jasperreports.engine.export.ooxml.XlsxStyleInfo Maven / Gradle / Ivy
/*
* JasperReports - Free Java Reporting Library.
* Copyright (C) 2001 - 2023 Cloud Software Group, Inc. All rights reserved.
* http://www.jaspersoft.com
*
* Unless you have purchased a commercial license agreement from Jaspersoft,
* the following license terms apply:
*
* This program is part of JasperReports.
*
* JasperReports is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* JasperReports 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with JasperReports. If not, see .
*/
package net.sf.jasperreports.engine.export.ooxml;
import net.sf.jasperreports.engine.JRPrintElement;
import net.sf.jasperreports.engine.JRStyle;
import net.sf.jasperreports.engine.JRTextAlignment;
import net.sf.jasperreports.engine.export.JRExporterGridCell;
import net.sf.jasperreports.engine.export.JRXlsAbstractExporter;
import net.sf.jasperreports.engine.type.HorizontalTextAlignEnum;
import net.sf.jasperreports.engine.type.LineDirectionEnum;
import net.sf.jasperreports.engine.type.ModeEnum;
import net.sf.jasperreports.engine.type.VerticalTextAlignEnum;
import net.sf.jasperreports.engine.util.JRColorUtil;
import net.sf.jasperreports.engine.util.ObjectUtils;
/**
* @author Teodor Danciu ([email protected] )
*/
public class XlsxStyleInfo
{
/**
*
*/
protected int formatIndex;
protected int fontIndex;
protected int borderIndex;
protected String backcolor;
protected String horizontalAlign;
protected String verticalAlign;
protected boolean isWrapText = true;
protected boolean isHidden;
protected boolean isLocked;
protected boolean isShrinkToFit;
protected boolean isIgnoreTextFormatting;
protected int rotation;
protected boolean whitePageBackground;
protected boolean ignoreCellBackground;
protected boolean ignoreCellBorder;
protected LineDirectionEnum direction;
/**
*
*/
public XlsxStyleInfo(
int formatIndex,
int fontIndex,
int borderIndex,
boolean isWrapText,
boolean isHidden,
boolean isLocked,
boolean isShrinkToFit,
boolean isIgnoreTextFormatting,
int rotation,
JRXlsAbstractExporter.SheetInfo sheetInfo,
LineDirectionEnum direction
)
{
this.formatIndex = formatIndex;
this.fontIndex = isIgnoreTextFormatting ? -1 : fontIndex;
this.borderIndex = isIgnoreTextFormatting ? -1 : borderIndex;
this.isWrapText = isShrinkToFit ? false : isWrapText;
this.isHidden = isHidden;
this.isLocked = isLocked;
this.isShrinkToFit = isShrinkToFit;
this.rotation = rotation;
if(sheetInfo != null)
{
if(sheetInfo.whitePageBackground != null)
{
this.whitePageBackground = sheetInfo.whitePageBackground;
}
if(sheetInfo.ignoreCellBackground != null)
{
this.ignoreCellBackground = sheetInfo.ignoreCellBackground;
}
if(sheetInfo.ignoreCellBorder != null)
{
this.ignoreCellBorder = sheetInfo.ignoreCellBorder;
}
}
this.direction = direction;
}
public XlsxStyleInfo(
int formatIndex,
int fontIndex,
int borderIndex,
JRPrintElement element,
boolean isWrapText,
boolean isHidden,
boolean isLocked,
boolean isShrinkToFit,
boolean isIgnoreTextFormatting,
int rotation,
JRXlsAbstractExporter.SheetInfo sheetInfo,
LineDirectionEnum direction,
JRStyle parentStyle
)
{
this(formatIndex,
fontIndex,
borderIndex,
isWrapText,
isHidden,
isLocked,
isShrinkToFit,
isIgnoreTextFormatting,
rotation,
sheetInfo,
direction);
if (!isIgnoreTextFormatting)
{
if (element != null && element.getModeValue() == ModeEnum.OPAQUE)
{
this.backcolor = JRColorUtil.getColorHexa(element.getBackcolor());
}
else if (parentStyle != null && parentStyle.getBackcolor() != null)
{
this.backcolor = JRColorUtil.getColorHexa(parentStyle.getBackcolor());
}
}
JRTextAlignment align = element != null && element instanceof JRTextAlignment ? (JRTextAlignment)element : null;
if (align != null)
{
this.horizontalAlign = getHorizontalAlignment(align.getHorizontalTextAlign(), align.getVerticalTextAlign(), rotation);//FIXMEXLSX use common util
this.verticalAlign = getVerticalAlignment(align.getHorizontalTextAlign(), align.getVerticalTextAlign(), rotation);//FIXMEXLSX use common util
}
}
public XlsxStyleInfo(
int formatIndex,
int fontIndex,
int borderIndex,
JRExporterGridCell gridCell,
JRPrintElement element,
boolean isWrapText,
boolean isHidden,
boolean isLocked,
boolean isShrinkToFit,
boolean isIgnoreTextFormatting,
int rotation,
JRXlsAbstractExporter.SheetInfo sheetInfo,
LineDirectionEnum direction
)
{
this(formatIndex,
fontIndex,
borderIndex,
isWrapText,
isHidden,
isLocked,
isShrinkToFit,
isIgnoreTextFormatting,
rotation,
sheetInfo,
direction);
if (!isIgnoreTextFormatting)
{
if (element != null && element.getModeValue() == ModeEnum.OPAQUE)
{
this.backcolor = JRColorUtil.getColorHexa(element.getBackcolor());
}
else if (gridCell != null && gridCell.getBackcolor() != null)
{
this.backcolor = JRColorUtil.getColorHexa(gridCell.getBackcolor());
}
}
JRTextAlignment align = element != null && element instanceof JRTextAlignment ? (JRTextAlignment)element : null;
if (align != null)
{
this.horizontalAlign = getHorizontalAlignment(align.getHorizontalTextAlign(), align.getVerticalTextAlign(), rotation);//FIXMEXLSX use common util
this.verticalAlign = getVerticalAlignment(align.getHorizontalTextAlign(), align.getVerticalTextAlign(), rotation);//FIXMEXLSX use common util
}
}
protected String getHorizontalAlignment(HorizontalTextAlignEnum hAlign, VerticalTextAlignEnum vAlign, int rotation)
{
switch (rotation)
{
case 90:
{
switch (vAlign)
{
case JUSTIFIED :
{
hAlign = HorizontalTextAlignEnum.JUSTIFIED;
break;
}
case BOTTOM :
{
hAlign = HorizontalTextAlignEnum.RIGHT;
break;
}
case MIDDLE :
{
hAlign = HorizontalTextAlignEnum.CENTER;
break;
}
case TOP :
default:
{
hAlign = HorizontalTextAlignEnum.LEFT;
}
}
break;
}
case 180:
{
switch (vAlign)
{
case JUSTIFIED :
{
hAlign = HorizontalTextAlignEnum.JUSTIFIED;
break;
}
case BOTTOM :
{
hAlign = HorizontalTextAlignEnum.LEFT;
break;
}
case MIDDLE :
{
hAlign = HorizontalTextAlignEnum.CENTER;
break;
}
case TOP :
default:
{
hAlign = HorizontalTextAlignEnum.RIGHT;
}
}
break;
}
default:
{
}
}
return XlsxParagraphHelper.getHorizontalAlignment(hAlign);
}
protected String getVerticalAlignment(HorizontalTextAlignEnum hAlign, VerticalTextAlignEnum vAlign, int rotation)
{
switch (rotation)
{
case 90:
{
switch (hAlign)
{
case JUSTIFIED :
{
vAlign = VerticalTextAlignEnum.JUSTIFIED;
break;
}
case RIGHT :
{
vAlign = VerticalTextAlignEnum.TOP;
break;
}
case CENTER :
{
vAlign = VerticalTextAlignEnum.MIDDLE;
break;
}
case LEFT :
default:
{
vAlign = VerticalTextAlignEnum.BOTTOM;
}
}
break;
}
case 180:
{
switch (hAlign)
{
case JUSTIFIED :
{
vAlign = VerticalTextAlignEnum.JUSTIFIED;
break;
}
case RIGHT :
{
vAlign = VerticalTextAlignEnum.BOTTOM;
break;
}
case CENTER :
{
vAlign = VerticalTextAlignEnum.MIDDLE;
break;
}
case LEFT :
default:
{
vAlign = VerticalTextAlignEnum.TOP;
}
}
break;
}
default:
{
}
}
return XlsxParagraphHelper.getVerticalAlignment(vAlign);
}
@Override
public int hashCode()
{
int hash = 47 + formatIndex;
hash = 29 * hash + fontIndex;
hash = 29 * hash + borderIndex;
hash = 29 * hash + ObjectUtils.hashCode(backcolor);
hash = 29 * hash + ObjectUtils.hashCode(horizontalAlign);
hash = 29 * hash + ObjectUtils.hashCode(verticalAlign);
hash = 29 * hash + Boolean.hashCode(isWrapText);
hash = 29 * hash + Boolean.hashCode(isHidden);
hash = 29 * hash + Boolean.hashCode(isLocked);
hash = 29 * hash + Boolean.hashCode(isShrinkToFit);
hash = 29 * hash + rotation;
hash = 29 * hash + Boolean.hashCode(whitePageBackground);
hash = 29 * hash + Boolean.hashCode(ignoreCellBackground);
hash = 29 * hash + Boolean.hashCode(ignoreCellBorder);
hash = 29 * hash + ObjectUtils.hashCode(direction);
return hash;
}
@Override
public boolean equals(Object obj)
{
if (!(obj instanceof XlsxStyleInfo))
{
return false;
}
XlsxStyleInfo info = (XlsxStyleInfo) obj;
return formatIndex == info.formatIndex
&& fontIndex == info.fontIndex
&& borderIndex == info.borderIndex
&& ObjectUtils.equals(backcolor, info.backcolor)
&& ObjectUtils.equals(horizontalAlign, info.horizontalAlign)
&& ObjectUtils.equals(verticalAlign, info.verticalAlign)
&& isWrapText == info.isWrapText
&& isHidden == info.isHidden
&& isLocked == info.isLocked
&& isShrinkToFit == info.isShrinkToFit
&& rotation == info.rotation
&& whitePageBackground == info.whitePageBackground
&& ignoreCellBackground == info.ignoreCellBackground
&& ignoreCellBorder == info.ignoreCellBorder
&& direction == info.direction;
}
}