All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.poi.hwpf.usermodel.BorderCode Maven / Gradle / Ivy

/* ====================================================================
   Licensed to the Apache Software Foundation (ASF) under one or more
   contributor license agreements.  See the NOTICE file distributed with
   this work for additional information regarding copyright ownership.
   The ASF licenses this file to You under the Apache License, Version 2.0
   (the "License"); you may not use this file except in compliance with
   the License.  You may obtain a copy of the License at

       http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing, software
   distributed under the License is distributed on an "AS IS" BASIS,
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   See the License for the specific language governing permissions and
   limitations under the License.
==================================================================== */

package org.apache.poi.hwpf.usermodel;

import org.apache.poi.common.Duplicatable;
import org.apache.poi.util.BitField;
import org.apache.poi.util.BitFieldFactory;
import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.LittleEndianConsts;

/**
 * Mapping class for BRC80 structure (Border Code for Word 97)
 */
public final class BorderCode implements Duplicatable {

    public static final int SIZE = 4;

    private static final BitField _dptLineWidth = BitFieldFactory.getInstance(0x00ff);
    private static final BitField _brcType = BitFieldFactory.getInstance(0xff00);

    private static final BitField _ico = BitFieldFactory.getInstance(0x00ff);
    private static final BitField _dptSpace = BitFieldFactory.getInstance(0x1f00);
    private static final BitField _fShadow = BitFieldFactory.getInstance(0x2000);
    private static final BitField _fFrame = BitFieldFactory.getInstance(0x4000);

    private short _info;
    private short _info2;


  public BorderCode() {}

  public BorderCode(BorderCode other) {
    _info = other._info;
    _info2 = other._info2;
  }

  public BorderCode(byte[] buf, int offset)
  {
    _info = LittleEndian.getShort(buf, offset);
    _info2 = LittleEndian.getShort(buf, offset + LittleEndianConsts.SHORT_SIZE);
  }

  public void serialize(byte[] buf, int offset)
  {
    LittleEndian.putShort(buf, offset, _info);
    LittleEndian.putShort(buf, offset + LittleEndianConsts.SHORT_SIZE, _info2);
  }

  public int toInt()
  {
    byte[] buf = new byte[4];
    serialize(buf, 0);
    return LittleEndian.getInt(buf);
  }

  public boolean isEmpty()
  {
    return _info == 0 && _info2 == 0 || _info == -1;
  }

  @Override
  public boolean equals(Object o)
  {
    if (!(o instanceof BorderCode)) return false;
    BorderCode brc = (BorderCode)o;
    return _info == brc._info && _info2 == brc._info2;
  }

  @Override
  public int hashCode() {
      assert false : "hashCode not designed";
      return 42; // any arbitrary constant will do
  }

  @Override
  public BorderCode copy() {
    return new BorderCode(this);
  }

  /**
   * Width of a single line in 1/8 pt, max of 32 pt.
   */
  public int getLineWidth() {
    return _dptLineWidth.getShortValue(_info);
  }

  /**
   * @param lineWidth the width of the line to set
   */
  public void setLineWidth(int lineWidth) {
    _info = _dptLineWidth.setShortValue(_info, (short)lineWidth);
  }

  /**
   * Border type code:
   * 
    *
  • 0 none
  • *
  • 1 single
  • *
  • 2 thick
  • *
  • 3 double
  • *
  • 5 hairline
  • *
  • 6 dot
  • *
  • 7 dash large gap
  • *
  • 8 dot dash
  • *
  • 9 dot dot dash
  • *
  • 10 triple
  • *
  • 11 thin-thick small gap
  • *
  • 12 thick-thin small gap
  • *
  • 13 thin-thick-thin small gap
  • *
  • 14 thin-thick medium gap
  • *
  • 15 thick-thin medium gap
  • *
  • 16 thin-thick-thin medium gap
  • *
  • 17 thin-thick large gap
  • *
  • 18 thick-thin large gap
  • *
  • 19 thin-thick-thin large gap
  • *
  • 20 wave
  • *
  • 21 double wave
  • *
  • 22 dash small gap
  • *
  • 23 dash dot stroked
  • *
  • 24 emboss 3D
  • *
  • 25 engrave 3D
  • *
  • codes 64 - 230 represent border art types and are used only for page borders
  • *
*/ public int getBorderType() { return _brcType.getShortValue(_info); } public void setBorderType(int borderType) { _info = _brcType.setShortValue(_info, (short)borderType); } /** * Color: *
    *
  • 0 Auto
  • *
  • 1 Black
  • *
  • 2 Blue
  • *
  • 3 Cyan
  • *
  • 4 Green
  • *
  • 5 Magenta
  • *
  • 6 Red
  • *
  • 7 Yellow
  • *
  • 8 White
  • *
  • 9 DkBlue
  • *
  • 10 DkCyan
  • *
  • 11 DkGreen
  • *
  • 12 DkMagenta
  • *
  • 13 DkRed
  • *
  • 14 DkYellow
  • *
  • 15 DkGray
  • *
  • 16 LtGray
  • *
*/ public short getColor() { return _ico.getShortValue(_info2); } public void setColor(short color) { _info2 = _ico.setShortValue(_info2, color); } /** * Width of space to maintain between border and text within border. * *

Must be 0 when BRC is a substructure of TC. * *

Stored in points. */ public int getSpace() { return _dptSpace.getShortValue(_info2); } public void setSpace(int space) { _info2 = (short)_dptSpace.setValue(_info2, space); } /** * When true, border is drawn with shadow * Must be false when BRC is a substructure of the TC. */ public boolean isShadow() { return _fShadow.getValue(_info2) != 0; } public void setShadow(boolean shadow) { _info2 = (short)_fShadow.setValue(_info2, shadow ? 1 : 0); } /** * Don't reverse the border. */ public boolean isFrame() { return _fFrame.getValue(_info2) != 0; } public void setFrame(boolean frame) { _info2 = (short)_fFrame.setValue(_info2, frame ? 1 : 0); } @Override public String toString() { return isEmpty() ? "[BRC] EMPTY" : "[BRC]\n" + " .dptLineWidth = (" + getLineWidth() + " )\n" + " .brcType = (" + getBorderType() + " )\n" + " .ico = (" + getColor() + " )\n" + " .dptSpace = (" + getSpace() + " )\n" + " .fShadow = (" + isShadow() + " )\n" + " .fFrame = (" + isFrame() + " )\n"; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy