/*
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.batik.svggen;
import java.awt.geom.AffineTransform;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.io.OutputStream;
import org.apache.batik.ext.awt.image.spi.ImageWriter;
import org.apache.batik.ext.awt.image.spi.ImageWriterRegistry;
import org.apache.batik.util.Base64EncoderStream;
import org.w3c.dom.Element;
This subclass of ImageHandlerBase64Encoder
implements functionality specific to the cached version of the image encoder. Author: Paul Evenblij Version: $Id: CachedImageHandlerBase64Encoder.java 1805419 2017-08-18 13:04:30Z ssteiner $
/**
* This subclass of {@link ImageHandlerBase64Encoder} implements
* functionality specific to the cached version of the image
* encoder.
*
* @author <a href="mailto:paul_evenblij@compuware.com">Paul Evenblij</a>
* @version $Id: CachedImageHandlerBase64Encoder.java 1805419 2017-08-18 13:04:30Z ssteiner $
*/
public class CachedImageHandlerBase64Encoder extends DefaultCachedImageHandler {
Build a CachedImageHandlerBase64Encoder
instance.
/**
* Build a <code>CachedImageHandlerBase64Encoder</code> instance.
*/
public CachedImageHandlerBase64Encoder() {
super();
setImageCacher(new ImageCacher.Embedded());
}
Creates an Element which can refer to an image.
Note that no assumptions should be made by the caller about the
corresponding SVG tag.
/**
* Creates an Element which can refer to an image.
* Note that no assumptions should be made by the caller about the
* corresponding SVG tag.
*/
public Element createElement(SVGGeneratorContext generatorContext) {
// Create a DOM Element in SVG namespace to refer to an image
// For this cached version we return <use>
Element imageElement =
generatorContext.getDOMFactory().createElementNS(
SVG_NAMESPACE_URI, SVG_USE_TAG);
return imageElement;
}
public String getRefPrefix(){
return "";
}
Determines the transformation needed to get the cached image to
scale & position properly. Sets x and y attributes on the element
accordingly.
/**
* Determines the transformation needed to get the cached image to
* scale & position properly. Sets x and y attributes on the element
* accordingly.
*/
protected AffineTransform handleTransform(Element imageElement,
double x, double y,
double srcWidth,
double srcHeight,
double dstWidth,
double dstHeight,
SVGGeneratorContext generatorContext) {
// If scaling is necessary, create a transform, since "width" and "height"
// have no effect on a <use> element referring to an <image> element.
AffineTransform af = new AffineTransform();
double hRatio = dstWidth / srcWidth;
double vRatio = dstHeight / srcHeight;
af.translate(x,y);
if(hRatio != 1 || vRatio != 1) {
af.scale(hRatio, vRatio);
}
if (!af.isIdentity()){
return af;
} else {
return null;
}
}
Uses PNG encoding.
/**
* Uses PNG encoding.
*/
public void encodeImage(BufferedImage buf, OutputStream os)
throws IOException {
Base64EncoderStream b64Encoder = new Base64EncoderStream(os);
ImageWriter writer = ImageWriterRegistry.getInstance()
.getWriterFor("image/png");
writer.writeImage(buf, b64Encoder);
b64Encoder.close();
}
public int getBufferedImageType(){
return BufferedImage.TYPE_INT_ARGB;
}
}