亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? supbookrecord.java

?? java開發(fā)文檔之excel:jexcelapi_2_6_3.tar
?? JAVA
字號(hào):
/*********************************************************************
*
*      Copyright (C) 2002 Andrew Khan
*
* This library 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 2.1 of the License, or (at your option) any later version.
*
* This library 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 this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
***************************************************************************/

package jxl.write.biff;

import common.Assert;
import common.Logger;

import jxl.WorkbookSettings;
import jxl.biff.EncodedURLHelper;
import jxl.biff.IntegerHelper;
import jxl.biff.StringHelper;
import jxl.biff.Type;
import jxl.biff.WritableRecordData;

/**
 * Stores the supporting workbook information.  For files written by
 * JExcelApi this will only reference internal sheets
 */
class SupbookRecord extends WritableRecordData
{
  /**
   * The logger
   */
  private static Logger logger = Logger.getLogger(SupbookRecord.class);

  /**
   * The type of this supbook record
   */
  private SupbookType type;

  /**
   * The data to be written to the binary file
   */
  private byte[] data;

  /**
   * The number of sheets - internal & external supbooks only
   */
  private int numSheets;

  /**
   * The name of the external file
   */
  private String fileName;

  /**
   * The names of the external sheets
   */
  private String[] sheetNames;

  /**
   * The workbook settings
   */
  private WorkbookSettings workbookSettings;

  /**
   * The type of supbook this refers to
   */
  private static class SupbookType {};

  public final static SupbookType INTERNAL = new SupbookType();
  public final static SupbookType EXTERNAL = new SupbookType();
  public final static SupbookType ADDIN    = new SupbookType();
  public final static SupbookType LINK     = new SupbookType();
  public final static SupbookType UNKNOWN  = new SupbookType();
  
  /**
   * Constructor for add in function names
   */
  public SupbookRecord()
  {
    super(Type.SUPBOOK);
    type = ADDIN;
    try
    {
      throw new Exception();
    }
    catch (Exception e)
    {
      e.printStackTrace();
    }
  }

  /**
   * Constructor for internal sheets
   */
  public SupbookRecord(int sheets, WorkbookSettings ws)
  {
    super(Type.SUPBOOK);

    numSheets = sheets;
    type = INTERNAL;
    workbookSettings = ws;
  }

  /**
   * Constructor for external sheets
   *
   * @param fn the filename of the external supbook
   * @param ws the workbook settings
   */
  public SupbookRecord(String fn, WorkbookSettings ws)
  {
    super(Type.SUPBOOK);

    fileName = fn;
    numSheets = 1;
    sheetNames = new String[0];
    workbookSettings = ws;

    type = EXTERNAL;
  }

  /**
   * Constructor used when copying from an external workbook
   */
  public SupbookRecord(jxl.read.biff.SupbookRecord sr, WorkbookSettings ws)
  {
    super(Type.SUPBOOK);

    workbookSettings = ws;
    if (sr.getType() == sr.INTERNAL)
    {
      type = INTERNAL;
      numSheets = sr.getNumberOfSheets();
    }
    else if (sr.getType() == sr.EXTERNAL)
    {
      type = EXTERNAL;
      numSheets = sr.getNumberOfSheets();
      fileName = sr.getFileName();
      sheetNames = new String[numSheets];

      for (int i = 0; i < numSheets; i++)
      {
        sheetNames[i] = sr.getSheetName(i);
      }
    }

    if (sr.getType() == sr.ADDIN)
    {
      logger.warn("Supbook type is addin");
    }
  }

  /**
   * Initializes an internal supbook record
   * 
   * @param sr the read supbook record to copy from
   */
  private void initInternal(jxl.read.biff.SupbookRecord sr)
  {
    numSheets = sr.getNumberOfSheets();
    initInternal();
  }

  /**
   * Initializes an internal supbook record
   */
  private void initInternal()
  {
    data = new byte[4];

    IntegerHelper.getTwoBytes(numSheets, data, 0);
    data[2] = 0x1;
    data[3] = 0x4;    
    type = INTERNAL;
  }

  /**
   * Adjust the number of internal sheets.  Called by WritableSheet when
   * a sheet is added or or removed to the workbook
   *
   * @param sheets the new number of sheets
   */
  void adjustInternal(int sheets)
  {
    Assert.verify(type == INTERNAL);
    numSheets = sheets;
    initInternal();
  }

  /**
   * Initializes an external supbook record
   */
  private void initExternal()
  {
    int totalSheetNameLength = 0;
    for (int i = 0; i < numSheets; i++)
    {
      totalSheetNameLength += sheetNames[i].length();
    }

    byte[] fileNameData = EncodedURLHelper.getEncodedURL(fileName, 
                                                         workbookSettings);
    int dataLength = 2 + // numsheets
      4 + fileNameData.length +
      numSheets * 3 + totalSheetNameLength * 2;
      
    data = new byte[dataLength];

    IntegerHelper.getTwoBytes(numSheets, data, 0);
    
    // Add in the file name.  Precede with a byte denoting that it is a 
    // file name
    int pos = 2;
    IntegerHelper.getTwoBytes(fileNameData.length+1, data, pos);
    data[pos+2] = 0; // ascii indicator
    data[pos+3] = 1; // file name indicator
    System.arraycopy(fileNameData, 0, data, pos+4, fileNameData.length);

    pos += 4 + fileNameData.length;

    // Get the sheet names
    for (int i = 0; i < sheetNames.length; i++)
    {
      IntegerHelper.getTwoBytes(sheetNames[i].length(), data, pos);
      data[pos+2] = 1; // unicode indicator
      StringHelper.getUnicodeBytes(sheetNames[i], data, pos+3);
      pos += 3 + sheetNames[i].length() * 2;
    }
  }

  /**
   * Initializes the supbook record for add in functions
   */
  private void initAddin()
  {
    data = new byte[] {0x1, 0x0, 0x1, 0x3a};
  }

  /**
   * The binary data to be written out
   * 
   * @return the binary data
   */
  public byte[] getData()
  {
    if (type == INTERNAL)
    {
      initInternal();
    }
    else if (type == EXTERNAL)
    {
      initExternal();
    }
    else if (type == ADDIN)
    {
      initAddin();
    }
    else
    {
      logger.warn("unsupported supbook type - defaulting to internal");
      initInternal();
    }

    return data;
  }

  /**
   * Gets the type of this supbook record
   * 
   * @return the type of this supbook
   */
  public SupbookType getType()
  {
    return type;
  }

  /**
   * Gets the number of sheets.  This will only be non-zero for internal
   * and external supbooks
   *
   * @return the number of sheets
   */
  public int getNumberOfSheets()
  {
    return numSheets;
  }

  /**
   * Accessor for the file name
   *
   * @return the file name
   */
  public String getFileName()
  {
    return fileName;
  }

  /**
   * Adds the worksheet name to this supbook
   *
   * @param name the worksheet name
   * @return the index of this sheet in the supbook record
   */
  public int getSheetIndex(String s)
  {
    boolean found = false;
    int sheetIndex = 0;
    for (int i = 0; i < sheetNames.length && !found; i++)
    {
      if (sheetNames[i].equals(s))
      {
        found = true;
        sheetIndex = 0;
      }
    }

    if (found)
    {
      return sheetIndex;
    }

    // Grow the array
    String[] names = new String[sheetNames.length + 1];
    names[sheetNames.length] = s;
    sheetNames = names;
    return sheetNames.length - 1;
  }

  /**
   * Accessor for the sheet name
   * 
   * @param s the sheet index
   */
  public String getSheetName(int s)
  {
    return sheetNames[s];
  }
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品看片你懂得| 久久99精品久久久久久| 制服丝袜在线91| 岛国精品在线观看| 日韩中文字幕区一区有砖一区| 国产亚洲欧洲一区高清在线观看| 欧美又粗又大又爽| 成人精品国产一区二区4080| 日韩电影在线一区二区| 亚洲天天做日日做天天谢日日欢 | 日韩亚洲欧美综合| 成人av在线资源网站| 日韩精品成人一区二区在线| 亚洲图片另类小说| 日本一区二区三区国色天香 | 中文字幕中文字幕一区| 日韩你懂的在线观看| 欧美精品777| 欧洲国内综合视频| 91美女视频网站| 成人激情免费网站| 国产精品538一区二区在线| 免费人成网站在线观看欧美高清| 亚洲一二三四在线| 亚洲另类在线视频| 欧美色视频在线| www.亚洲色图.com| 激情成人午夜视频| 日韩av在线发布| 亚洲国产综合视频在线观看| 亚洲免费在线观看| 亚洲精品国产视频| 亚洲男同性视频| 一区二区三区毛片| 亚洲电影一区二区三区| 洋洋av久久久久久久一区| 亚洲精品国产无套在线观| 亚洲精品一卡二卡| 亚洲一级二级在线| 性做久久久久久久免费看| 日韩专区一卡二卡| 麻豆成人久久精品二区三区小说| 日日欢夜夜爽一区| 欧美aⅴ一区二区三区视频| 免费在线看一区| 国产尤物一区二区在线| 国产91露脸合集magnet| 国产凹凸在线观看一区二区| 成人性生交大合| 97se亚洲国产综合在线| 在线免费不卡电影| 91精品国产一区二区三区蜜臀| 欧美精品在线一区二区三区| 欧美成人一级视频| 国产日韩av一区二区| 自拍偷在线精品自拍偷无码专区| 一区二区三区四区不卡视频| 亚洲国产精品一区二区久久 | 欧美日韩激情一区二区| 欧美美女一区二区三区| 欧美大胆人体bbbb| 久久久精品2019中文字幕之3| 中文欧美字幕免费| 亚洲国产精品一区二区www| 日本欧美久久久久免费播放网| 久久99国产精品久久| 成人网在线免费视频| 91福利视频久久久久| 欧美一级在线免费| 国产精品久久久久久福利一牛影视| 一区二区三区在线视频观看| 麻豆成人av在线| 99热99精品| 日韩精品资源二区在线| 中文字幕第一区二区| 天天综合色天天综合色h| 国产一区二区三区观看| 91成人国产精品| 欧美精品一区男女天堂| 一区二区视频在线| 国产在线国偷精品免费看| 91九色02白丝porn| 久久综合精品国产一区二区三区| 亚洲色图视频网| 国内精品国产成人国产三级粉色| 99精品国产热久久91蜜凸| 日韩手机在线导航| 1000精品久久久久久久久| 美女一区二区久久| 日本精品裸体写真集在线观看| 欧美大片在线观看| 亚洲午夜在线电影| bt欧美亚洲午夜电影天堂| 欧美一区二区三区四区高清| 亚洲欧洲美洲综合色网| 久久99热国产| 欧美丝袜丝交足nylons图片| 国产日产欧美一区| 免费高清在线一区| 欧美日韩一区在线观看| 中文字幕成人网| 黄色资源网久久资源365| 精品视频资源站| 最新国产成人在线观看| 国产精品亚洲专一区二区三区| 欧美日韩高清影院| 亚洲欧美另类久久久精品2019| 国产永久精品大片wwwapp| 日韩视频永久免费| 亚洲不卡在线观看| 91久久国产最好的精华液| 国产精品久久久久四虎| 国产成人免费视| 精品日产卡一卡二卡麻豆| 午夜精品福利在线| 欧洲国内综合视频| 亚洲日本欧美天堂| 99精品桃花视频在线观看| 欧美国产精品一区| 国产精品一区二区久激情瑜伽| 精品久久人人做人人爱| 美腿丝袜一区二区三区| 欧美一级欧美三级在线观看| 亚洲第一激情av| 欧美日韩高清不卡| 天涯成人国产亚洲精品一区av| 91麻豆免费在线观看| 亚洲免费资源在线播放| 91久色porny | 欧美日韩精品欧美日韩精品一| 一个色在线综合| 欧美日韩卡一卡二| 亚洲国产精品久久人人爱| 欧美亚洲国产一区二区三区| 亚洲精品中文字幕在线观看| 一本色道久久综合狠狠躁的推荐| 综合激情成人伊人| 色哟哟一区二区三区| 亚洲第一电影网| 7777精品伊人久久久大香线蕉完整版| 亚洲国产wwwccc36天堂| 欧美男人的天堂一二区| 日韩精品乱码av一区二区| 日韩一区二区三| 国产一区二区按摩在线观看| 中文在线资源观看网站视频免费不卡| 国产精品91一区二区| 国产精品蜜臀av| 欧美视频一区在线| 蜜臀av国产精品久久久久| 亚洲精品在线三区| 成人丝袜视频网| 亚洲欧美偷拍三级| 69av一区二区三区| 激情综合色综合久久综合| 中文字幕av不卡| 欧美主播一区二区三区美女| 五月激情综合网| 2023国产精品视频| 99视频在线精品| 日韩和欧美的一区| 久久午夜羞羞影院免费观看| 成人高清av在线| 三级影片在线观看欧美日韩一区二区 | 亚洲综合免费观看高清完整版 | 色综合久久88色综合天天免费| 亚洲国产精品久久久久秋霞影院| 日韩一二三区视频| 成人动漫中文字幕| 亚洲成在人线在线播放| 精品国产成人在线影院| 成人激情综合网站| 日本中文一区二区三区| 国产亚洲午夜高清国产拍精品 | 欧美视频一区二区在线观看| 久久精品国产一区二区三| 国产精品三级av| 欧美丰满高潮xxxx喷水动漫| 成人性色生活片免费看爆迷你毛片| 亚洲精品视频在线观看网站| 精品乱人伦小说| 日本丰满少妇一区二区三区| 蜜臀av性久久久久蜜臀av麻豆| 国产精品久久免费看| 5566中文字幕一区二区电影 | caoporn国产精品| 免费精品视频在线| 国产精品传媒入口麻豆| 精品欧美一区二区三区精品久久| 色综合视频在线观看| 国产乱子轮精品视频| 亚洲福利视频一区二区| 国产精品入口麻豆原神| 欧美一区二视频| 色婷婷亚洲综合| 国产suv一区二区三区88区| 日本女人一区二区三区| 亚洲伦理在线免费看| 亚洲国产电影在线观看| 精品欧美一区二区久久|