Categories:
Audio (13)
Biotech (29)
Bytecode (36)
Database (77)
Framework (7)
Game (7)
General (507)
Graphics (53)
I/O (35)
IDE (2)
JAR Tools (101)
JavaBeans (21)
JDBC (121)
JDK (426)
JSP (20)
Logging (108)
Mail (58)
Messaging (8)
Network (84)
PDF (97)
Report (7)
Scripting (84)
Security (32)
Server (121)
Servlet (26)
SOAP (24)
Testing (54)
Web (15)
XML (309)
Collections:
Other Resources:
What Is poi-scratchpad-5.2.3.jar?
What Is poi-scratchpad-5.2.3.jar?
✍: FYIcenter.com
poi-scratchpad-5.2.3.jar is one of the JAR files for Apache POI 5.2.3, which provides an API for Microsoft document files of Word, Excel, PowerPoint, and Visio.
poi-scratchpad-5.2.3.jar provides support for older versions of Microsoft document files like Word 97, Excel 97, PowerPoint 97, etc.
poi-scratchpad-5.2.3.jar is distributed as part of the poi-bin-5.2.3-20220909.zip download file.
JAR File Size and Download Location:
JAR name: poi-scratchpad-5.2.3.jar Target JDK version: 9 Dependency: poi.jar File name: poi-scratchpad.jar, poi-scratchpad-5.2.3.jar File size: 1897121 bytes Release date: 09-09-2022 Download: Apache POI Website
Here are Java Source Code files for poi-scratchpad-5.2.3.jar:
⏎ org/apache/poi/hemf/record/emfplus/HemfPlusMisc.java
/* ==================================================================== 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.hemf.record.emfplus; import static org.apache.poi.hemf.record.emfplus.HemfPlusDraw.readRectF; import static org.apache.poi.util.GenericRecordUtil.getBitsAsString; import java.awt.Shape; import java.awt.geom.AffineTransform; import java.awt.geom.Point2D; import java.awt.geom.Rectangle2D; import java.io.IOException; import java.util.Map; import java.util.function.Supplier; import org.apache.poi.hemf.draw.HemfDrawProperties; import org.apache.poi.hemf.draw.HemfGraphics; import org.apache.poi.hemf.record.emf.HemfFill; import org.apache.poi.hemf.record.emf.HemfRecord.RenderBounds; import org.apache.poi.hwmf.record.HwmfRegionMode; import org.apache.poi.util.BitField; import org.apache.poi.util.BitFieldFactory; import org.apache.poi.util.GenericRecordUtil; import org.apache.poi.util.LittleEndianConsts; import org.apache.poi.util.LittleEndianInputStream; @SuppressWarnings("WeakerAccess") public class HemfPlusMisc { public interface EmfPlusObjectId { BitField OBJECT_ID = BitFieldFactory.getInstance(0x00FF); int getFlags(); /** * The index in the EMF+ Object Table to associate with the object * created by this record. The value MUST be zero to 63, inclusive. */ default int getObjectId() { return OBJECT_ID.getValue(getFlags()); } } public enum CombineMode { REPLACE(0x00000000, HwmfRegionMode.RGN_COPY), INTERSECT(0x00000001, HwmfRegionMode.RGN_AND), UNION(0x00000002, HwmfRegionMode.RGN_OR), XOR(0x00000003, HwmfRegionMode.RGN_XOR), EXCLUDE(0x00000004, HwmfRegionMode.RGN_DIFF), COMPLEMENT(0x00000005, HwmfRegionMode.RGN_COMPLEMENT) ; public final int id; public final HwmfRegionMode regionMode; CombineMode(int id, HwmfRegionMode regionMode) { this.id = id; this.regionMode = regionMode; } public static CombineMode valueOf(int id) { for (CombineMode wrt : values()) { if (wrt.id == id) return wrt; } return null; } } public static abstract class EmfPlusFlagOnly implements HemfPlusRecord { private int flags; private HemfPlusRecordType recordType; private static final int[] FLAGS_MASK = { 0x0F00 }; private static final String[] FLAGS_NAMES = { "COMBINE_MODE" }; @Override public int getFlags() { return flags; } @Override public final HemfPlusRecordType getEmfPlusRecordType() { return recordType; } @Override public long init(LittleEndianInputStream leis, long dataSize, long recordId, int flags) throws IOException { this.flags = flags; assert(dataSize == 0); recordType = HemfPlusRecordType.getById(recordId); return 0; } @Override public HemfPlusRecordType getGenericRecordType() { return getEmfPlusRecordType(); } @Override public Map<String, Supplier<?>> getGenericProperties() { return GenericRecordUtil.getGenericProperties( "flags", getBitsAsString(this::getFlags,FLAGS_MASK,FLAGS_NAMES) ); } } public static class EmfPlusEOF extends EmfPlusFlagOnly { } /** * The EmfPlusSetPixelOffsetMode record specifies how pixels are centered with respect to the * coordinates of the drawing surface. */ public static class EmfPlusSetPixelOffsetMode extends EmfPlusFlagOnly { } /** * The EmfPlusSetAntiAliasMode record specifies the anti-aliasing mode for text output. */ public static class EmfPlusSetAntiAliasMode extends EmfPlusFlagOnly { } /** * The EmfPlusSetCompositingMode record specifies how source colors are combined with background colors. */ public static class EmfPlusSetCompositingMode extends EmfPlusFlagOnly { } /** * The EmfPlusSetCompositingQuality record specifies the desired level of quality for creating * composite images from multiple objects. */ public static class EmfPlusSetCompositingQuality extends EmfPlusFlagOnly { } /** * The EmfPlusSetInterpolationMode record specifies how image scaling, including stretching and * shrinking, is performed. */ public static class EmfPlusSetInterpolationMode extends EmfPlusFlagOnly { } /** * The EmfPlusGetDC record specifies that subsequent EMF records encountered in the metafile * SHOULD be processed. */ public static class EmfPlusGetDC extends EmfPlusFlagOnly { @Override public void draw(HemfGraphics ctx) { ctx.setRenderState(HemfGraphics.EmfRenderState.EMF_DCONTEXT); } @Override public void calcBounds(RenderBounds holder) { holder.setState(HemfGraphics.EmfRenderState.EMF_DCONTEXT); } } /** * The EmfPlusSetTextRenderingHint record specifies the quality of text rendering, including the type * of anti-aliasing. */ public static class EmfPlusSetTextRenderingHint extends EmfPlusFlagOnly { } /** * The EmfPlusResetWorldTransform record resets the current world space transform to the identify matrix. */ public static class EmfPlusResetWorldTransform extends EmfPlusFlagOnly { @Override public void draw(HemfGraphics ctx) { HemfDrawProperties prop = ctx.getProperties(); prop.clearTransform(); ctx.updateWindowMapMode(); } } /** * The EmfPlusSetWorldTransform record sets the world transform according to the values in a * specified transform matrix. */ public static class EmfPlusSetWorldTransform implements HemfPlusRecord { private int flags; private final AffineTransform matrixData = new AffineTransform(); @Override public HemfPlusRecordType getEmfPlusRecordType() { return HemfPlusRecordType.setWorldTransform; } @Override public int getFlags() { return flags; } @Override public long init(LittleEndianInputStream leis, long dataSize, long recordId, int flags) throws IOException { this.flags = flags; return HemfFill.readXForm(leis, matrixData); } public AffineTransform getMatrixData() { return matrixData; } @Override public void draw(HemfGraphics ctx) { HemfDrawProperties prop = ctx.getProperties(); prop.clearTransform(); prop.addLeftTransform(getMatrixData()); ctx.updateWindowMapMode(); } @Override public Map<String, Supplier<?>> getGenericProperties() { return GenericRecordUtil.getGenericProperties( "flags", this::getFlags, "matrixData", this::getMatrixData ); } } /** * The EmfPlusMultiplyWorldTransform record multiplies the current world space transform by a * specified transform matrix. */ public static class EmfPlusMultiplyWorldTransform extends EmfPlusSetWorldTransform { @Override public HemfPlusRecordType getEmfPlusRecordType() { return HemfPlusRecordType.multiplyWorldTransform; } @Override public void draw(HemfGraphics ctx) { AffineTransform tx = ctx.getInitTransform(); tx.concatenate(getMatrixData()); ctx.setTransform(tx); // don't call ctx.updateWindowMapMode(); } } /** * The EmfPlusSetPageTransform record specifies scaling factors and units for converting page space * coordinates to device space coordinates. */ public static class EmfPlusSetPageTransform implements HemfPlusRecord { private int flags; private double pageScale; @Override public HemfPlusRecordType getEmfPlusRecordType() { return HemfPlusRecordType.setPageTransform; } @Override public int getFlags() { return flags; } @Override public long init(LittleEndianInputStream leis, long dataSize, long recordId, int flags) throws IOException { this.flags = flags; pageScale = leis.readFloat(); return LittleEndianConsts.INT_SIZE; } public double getPageScale() { return pageScale; } @Override public Map<String, Supplier<?>> getGenericProperties() { return GenericRecordUtil.getGenericProperties( "flags", this::getFlags, "pageScale", this::getPageScale ); } } /** * The EmfPlusSetClipRegion record combines the current clipping region with another graphics region. */ public static class EmfPlusSetClipRegion extends EmfPlusSetClipPath { } /** * The EmfPlusSetClipPath record combines the current clipping region with a graphics path. */ public static class EmfPlusSetClipPath extends EmfPlusFlagOnly implements EmfPlusObjectId { private static final BitField COMBINE_MODE = BitFieldFactory.getInstance(0x0F00); public CombineMode getCombineMode() { return CombineMode.valueOf(COMBINE_MODE.getValue(getFlags())); } @Override public void draw(HemfGraphics ctx) { HemfDrawProperties prop = ctx.getProperties(); ctx.applyPlusObjectTableEntry(getObjectId()); Shape clip = prop.getPath(); ctx.setClip(clip, clip == null ? HwmfRegionMode.RGN_COPY : getCombineMode().regionMode, false); } } /** The EmfPlusSetClipRect record combines the current clipping region with a rectangle. */ @SuppressWarnings("unused") public static class EmfPlusSetClipRect implements HemfPlusRecord { private static final BitField COMBINE_MODE = BitFieldFactory.getInstance(0x0F00); private static final int[] FLAGS_MASK = { 0x0F00 }; private static final String[] FLAGS_NAMES = { "COMBINE_MODE" }; private int flags; private final Rectangle2D clipRect = new Rectangle2D.Double(); @Override public HemfPlusRecordType getEmfPlusRecordType() { return HemfPlusRecordType.setClipRect; } @Override public int getFlags() { return flags; } public CombineMode getCombineMode() { return CombineMode.valueOf(COMBINE_MODE.getValue(getFlags())); } @Override public long init(LittleEndianInputStream leis, long dataSize, long recordId, int flags) throws IOException { this.flags = flags; // An EmfPlusRectF object that defines the rectangle to use in the CombineMode operation. return readRectF(leis, clipRect); } public Rectangle2D getClipRect() { return clipRect; } @Override public Map<String, Supplier<?>> getGenericProperties() { return GenericRecordUtil.getGenericProperties( "flags", getBitsAsString(this::getFlags, FLAGS_MASK, FLAGS_NAMES), "clipRect", this::getClipRect ); } } /** The EmfPlusResetClip record resets the current clipping region for the world space to infinity. */ public static class EmfPlusResetClip extends EmfPlusFlagOnly { } /** * The EmfPlusSave record saves the graphics state, identified by a specified index, on a stack of saved * graphics states. */ public static class EmfPlusSave implements HemfPlusRecord { private int flags; private int stackIndex; @Override public HemfPlusRecordType getEmfPlusRecordType() { return HemfPlusRecordType.save; } @Override public int getFlags() { return flags; } public int getStackIndex() { return stackIndex; } @Override public long init(LittleEndianInputStream leis, long dataSize, long recordId, int flags) throws IOException { this.flags = flags; // A 32-bit unsigned integer that specifies a level to associate with the graphics state. // The level value can be used by a subsequent EmfPlusRestore record operation to retrieve the graphics state. stackIndex = leis.readInt(); return LittleEndianConsts.INT_SIZE; } @Override public void draw(HemfGraphics ctx) { ctx.savePlusProperties(getStackIndex()); } @Override public Map<String, Supplier<?>> getGenericProperties() { return GenericRecordUtil.getGenericProperties( "flags", this::getFlags, "stackIndex", this::getStackIndex ); } } /** * The EmfPlusRestore record restores the graphics state, identified by a specified index, from a stack * of saved graphics states. */ public static class EmfPlusRestore extends EmfPlusSave { @Override public HemfPlusRecordType getEmfPlusRecordType() { return HemfPlusRecordType.restore; } @Override public void draw(HemfGraphics ctx) { ctx.restorePlusProperties(getStackIndex()); } } /** The EmfPlusSetRenderingOrigin record specifies the rendering origin for graphics output. */ public static class EmfPlusSetRenderingOrigin implements HemfPlusRecord { int flags; Point2D origin = new Point2D.Double(); @Override public HemfPlusRecordType getEmfPlusRecordType() { return HemfPlusRecordType.setRenderingOrigin; } @Override public int getFlags() { return flags; } public Point2D getOrigin() { return origin; } @Override public long init(LittleEndianInputStream leis, long dataSize, long recordId, int flags) throws IOException { this.flags = flags; // error in the MS-EMFPLUS docs - its a signed integer instead of an unsigned // A 32-bit signed integer that defines the horizontal coordinate value of the rendering origin. int x = leis.readInt(); // A 32-bit signed integer that defines the vertical coordinate value of the rendering origin. int y = leis.readInt(); origin.setLocation(x,y); return LittleEndianConsts.INT_SIZE*2L; } @Override public Map<String, Supplier<?>> getGenericProperties() { return GenericRecordUtil.getGenericProperties( "flags", this::getFlags, "origin", this::getOrigin ); } } }
⏎ org/apache/poi/hemf/record/emfplus/HemfPlusMisc.java
Or download all of them as a single archive file:
File name: poi-scratchpad-5.2.3-src.zip File size: 1238744 bytes Release date: 2022-09-09 Download
⇒ What Is poi-examples-5.2.3.jar?
⇐ What Is poi-excelant-5.2.3.jar?
2017-03-22, 33651👍, 0💬
Popular Posts:
Apache Log4j IOStreams is a Log4j API extension that provides numerous classes from java.io that can...
Java Cryptography Extension 1.6 JAR File Size and Download Location: File name: jce.jar, jce-1.6.jar...
xml-commons External Source Code Files are provided in the source package file, xml-commons-external...
iText is an ideal library for developers looking to enhance web- and other applications with dynamic...
JDK 11 jdk.crypto.cryptoki.jmod is the JMOD file for JDK 11 Crypto Cryptoki module. JDK 11 Crypto KI...