// Copyright 2002, FreeHEP. package org.freehep.graphicsio.emf.gdi; import com.google.code.appengine.awt.Point; import com.google.code.appengine.awt.Rectangle; import java.io.IOException; import org.freehep.graphicsio.emf.EMFInputStream; import org.freehep.graphicsio.emf.EMFOutputStream; import org.freehep.graphicsio.emf.EMFTag; /** * PolyPolygon TAG. * * @author Mark Donszelmann * @version $Id: PolyPolygon.java 10377 2007-01-23 15:44:34Z duns $ */ public class PolyPolygon extends AbstractPolyPolygon { private int start, end; public PolyPolygon() { super(8, 1, null, null, null); } public PolyPolygon( Rectangle bounds, int start, int end, int[] numberOfPoints, Point[][] points) { super(8, 1, bounds, numberOfPoints, points); this.start = start; this.end = end; } public EMFTag read(int tagID, EMFInputStream emf, int len) throws IOException { Rectangle bounds = emf.readRECTL(); int np = emf.readDWORD(); /* int totalNumberOfPoints = */ emf.readDWORD(); int[] pc = new int[np]; Point[][] points = new Point[np][]; for (int i = 0; i < np; i++) { pc[i] = emf.readDWORD(); points[i] = new Point[pc[i]]; } for (int i = 0; i < np; i++) { points[i] = emf.readPOINTL(pc[i]); } return new PolyPolygon(bounds, 0, np - 1, pc, points); } public void write(int tagID, EMFOutputStream emf) throws IOException { int[] numberOfPoints = getNumberOfPoints(); Point[][] points = getPoints(); emf.writeRECTL(getBounds()); emf.writeDWORD(end - start + 1); int c = 0; for (int i = start; i < end + 1; i++) { c += numberOfPoints[i]; } emf.writeDWORD(c); for (int i = start; i < end + 1; i++) { emf.writeDWORD(numberOfPoints[i]); } for (int i = start; i < end + 1; i++) { emf.writePOINTL(numberOfPoints[i], points[i]); } } }