/*
* 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 pdfimport.pdfbox.operators;
import java.awt.geom.GeneralPath;
import java.awt.geom.Point2D;
import java.util.List;
import org.apache.pdfbox.cos.COSBase;
import org.apache.pdfbox.cos.COSNumber;
import org.apache.pdfbox.util.PDFOperator;
import org.apache.pdfbox.util.operator.OperatorProcessor;
import pdfimport.pdfbox.PageDrawer;
/**
* Implementation of content stream operator for page drawer.
*
* @author <a href="mailto:ben@benlitchfield.com">Ben Litchfield</a>
* @version $Revision: 1.3 $
*/
public class AppendRectangleToPath extends OperatorProcessor
{
/**
* process : re : append rectangle to path.
* @param operator The operator that is being executed.
* @param arguments List
*/
@Override
public void process(PDFOperator operator, List<COSBase> arguments)
{
PageDrawer drawer = (PageDrawer)context;
COSNumber x = (COSNumber)arguments.get( 0 );
COSNumber y = (COSNumber)arguments.get( 1 );
COSNumber w = (COSNumber)arguments.get( 2 );
COSNumber h = (COSNumber)arguments.get( 3 );
double x1 = x.doubleValue();
double y1 = y.doubleValue();
// create a pair of coordinates for the transformation
double x2 = w.doubleValue()+x1;
double y2 = h.doubleValue()+y1;
Point2D startCoords = drawer.transformedPoint(x1,y1);
Point2D endCoords = drawer.transformedPoint(x2,y2);
float width = (float)(endCoords.getX()-startCoords.getX());
float height = (float)(endCoords.getY()-startCoords.getY());
float xStart = (float)startCoords.getX();
float yStart = (float)startCoords.getY();
// To ensure that the path is created in the right direction,
// we have to create it by combining single lines instead of
// creating a simple rectangle
GeneralPath path = drawer.getLinePath();
path.moveTo(xStart, yStart);
path.lineTo(xStart+width, yStart);
path.lineTo(xStart+width, yStart+height);
path.lineTo(xStart, yStart+height);
path.lineTo(xStart, yStart);
}
}