SVG symbols: allow custom creation, #74
This commit is contained in:
parent
21ea5a7842
commit
3d6cad1a0c
@ -28,35 +28,59 @@ import java.io.InputStream;
|
||||
|
||||
public class AndroidSvgBitmap extends AndroidBitmap {
|
||||
/**
|
||||
* Default size is 20x20px at baseline mdpi (160dpi).
|
||||
* Default size is 20x20px (400px) at baseline mdpi (160dpi).
|
||||
*/
|
||||
public static float DEFAULT_SIZE = 400f;
|
||||
|
||||
private static android.graphics.Bitmap getResourceBitmap(InputStream inputStream) throws IOException {
|
||||
synchronized (SVG.getVersion()) {
|
||||
try {
|
||||
SVG svg = SVG.getFromInputStream(inputStream);
|
||||
Picture picture = svg.renderToPicture();
|
||||
public static android.graphics.Bitmap getResourceBitmap(InputStream inputStream, float scaleFactor, float defaultSize, int width, int height, int percent) throws IOException {
|
||||
try {
|
||||
SVG svg = SVG.getFromInputStream(inputStream);
|
||||
Picture picture = svg.renderToPicture();
|
||||
|
||||
float scaleFactor = CanvasAdapter.dpi / 160;
|
||||
double scale = scaleFactor / Math.sqrt((picture.getHeight() * picture.getWidth()) / DEFAULT_SIZE);
|
||||
double scale = scaleFactor / Math.sqrt((picture.getHeight() * picture.getWidth()) / defaultSize);
|
||||
|
||||
float bitmapWidth = (float) (picture.getWidth() * scale);
|
||||
float bitmapHeight = (float) (picture.getHeight() * scale);
|
||||
float bitmapWidth = (float) (picture.getWidth() * scale);
|
||||
float bitmapHeight = (float) (picture.getHeight() * scale);
|
||||
|
||||
android.graphics.Bitmap bitmap = android.graphics.Bitmap.createBitmap((int) Math.ceil(bitmapWidth),
|
||||
(int) Math.ceil(bitmapHeight), Bitmap.Config.ARGB_8888);
|
||||
Canvas canvas = new Canvas(bitmap);
|
||||
canvas.drawPicture(picture, new RectF(0, 0, bitmapWidth, bitmapHeight));
|
||||
float aspectRatio = (1f * picture.getWidth()) / picture.getHeight();
|
||||
|
||||
return bitmap;
|
||||
} catch (Exception e) {
|
||||
throw new IOException(e);
|
||||
if (width != 0 && height != 0) {
|
||||
// both width and height set, override any other setting
|
||||
bitmapWidth = width;
|
||||
bitmapHeight = height;
|
||||
} else if (width == 0 && height != 0) {
|
||||
// only width set, calculate from aspect ratio
|
||||
bitmapWidth = height * aspectRatio;
|
||||
bitmapHeight = height;
|
||||
} else if (width != 0 && height == 0) {
|
||||
// only height set, calculate from aspect ratio
|
||||
bitmapHeight = width / aspectRatio;
|
||||
bitmapWidth = width;
|
||||
}
|
||||
|
||||
if (percent != 100) {
|
||||
bitmapWidth *= percent / 100f;
|
||||
bitmapHeight *= percent / 100f;
|
||||
}
|
||||
|
||||
android.graphics.Bitmap bitmap = android.graphics.Bitmap.createBitmap((int) Math.ceil(bitmapWidth),
|
||||
(int) Math.ceil(bitmapHeight), Bitmap.Config.ARGB_8888);
|
||||
Canvas canvas = new Canvas(bitmap);
|
||||
canvas.drawPicture(picture, new RectF(0, 0, bitmapWidth, bitmapHeight));
|
||||
|
||||
return bitmap;
|
||||
} catch (Exception e) {
|
||||
throw new IOException(e);
|
||||
}
|
||||
}
|
||||
|
||||
AndroidSvgBitmap(InputStream inputStream) throws IOException {
|
||||
super(getResourceBitmap(inputStream));
|
||||
private static android.graphics.Bitmap getResourceBitmapImpl(InputStream inputStream) throws IOException {
|
||||
synchronized (SVG.getVersion()) {
|
||||
return getResourceBitmap(inputStream, CanvasAdapter.dpi / 160, DEFAULT_SIZE, 0, 0, 100);
|
||||
}
|
||||
}
|
||||
|
||||
public AndroidSvgBitmap(InputStream inputStream) throws IOException {
|
||||
super(getResourceBitmapImpl(inputStream));
|
||||
}
|
||||
}
|
||||
|
@ -28,35 +28,59 @@ import java.io.InputStream;
|
||||
|
||||
public class AndroidSvgBitmap extends AndroidBitmap {
|
||||
/**
|
||||
* Default size is 20x20px at baseline mdpi (160dpi).
|
||||
* Default size is 20x20px (400px) at baseline mdpi (160dpi).
|
||||
*/
|
||||
public static float DEFAULT_SIZE = 400f;
|
||||
|
||||
private static android.graphics.Bitmap getResourceBitmap(InputStream inputStream) throws IOException {
|
||||
synchronized (SVG.getVersion()) {
|
||||
try {
|
||||
SVG svg = SVG.getFromInputStream(inputStream);
|
||||
Picture picture = svg.renderToPicture();
|
||||
public static android.graphics.Bitmap getResourceBitmap(InputStream inputStream, float scaleFactor, float defaultSize, int width, int height, int percent) throws IOException {
|
||||
try {
|
||||
SVG svg = SVG.getFromInputStream(inputStream);
|
||||
Picture picture = svg.renderToPicture();
|
||||
|
||||
float scaleFactor = CanvasAdapter.dpi / 160;
|
||||
double scale = scaleFactor / Math.sqrt((picture.getHeight() * picture.getWidth()) / DEFAULT_SIZE);
|
||||
double scale = scaleFactor / Math.sqrt((picture.getHeight() * picture.getWidth()) / defaultSize);
|
||||
|
||||
float bitmapWidth = (float) (picture.getWidth() * scale);
|
||||
float bitmapHeight = (float) (picture.getHeight() * scale);
|
||||
float bitmapWidth = (float) (picture.getWidth() * scale);
|
||||
float bitmapHeight = (float) (picture.getHeight() * scale);
|
||||
|
||||
android.graphics.Bitmap bitmap = android.graphics.Bitmap.createBitmap((int) Math.ceil(bitmapWidth),
|
||||
(int) Math.ceil(bitmapHeight), Bitmap.Config.ARGB_8888);
|
||||
Canvas canvas = new Canvas(bitmap);
|
||||
canvas.drawPicture(picture, new RectF(0, 0, bitmapWidth, bitmapHeight));
|
||||
float aspectRatio = (1f * picture.getWidth()) / picture.getHeight();
|
||||
|
||||
return bitmap;
|
||||
} catch (Exception e) {
|
||||
throw new IOException(e);
|
||||
if (width != 0 && height != 0) {
|
||||
// both width and height set, override any other setting
|
||||
bitmapWidth = width;
|
||||
bitmapHeight = height;
|
||||
} else if (width == 0 && height != 0) {
|
||||
// only width set, calculate from aspect ratio
|
||||
bitmapWidth = height * aspectRatio;
|
||||
bitmapHeight = height;
|
||||
} else if (width != 0 && height == 0) {
|
||||
// only height set, calculate from aspect ratio
|
||||
bitmapHeight = width / aspectRatio;
|
||||
bitmapWidth = width;
|
||||
}
|
||||
|
||||
if (percent != 100) {
|
||||
bitmapWidth *= percent / 100f;
|
||||
bitmapHeight *= percent / 100f;
|
||||
}
|
||||
|
||||
android.graphics.Bitmap bitmap = android.graphics.Bitmap.createBitmap((int) Math.ceil(bitmapWidth),
|
||||
(int) Math.ceil(bitmapHeight), Bitmap.Config.ARGB_8888);
|
||||
Canvas canvas = new Canvas(bitmap);
|
||||
canvas.drawPicture(picture, new RectF(0, 0, bitmapWidth, bitmapHeight));
|
||||
|
||||
return bitmap;
|
||||
} catch (Exception e) {
|
||||
throw new IOException(e);
|
||||
}
|
||||
}
|
||||
|
||||
AndroidSvgBitmap(InputStream inputStream) throws IOException {
|
||||
super(getResourceBitmap(inputStream));
|
||||
private static android.graphics.Bitmap getResourceBitmapImpl(InputStream inputStream) throws IOException {
|
||||
synchronized (SVG.getVersion()) {
|
||||
return getResourceBitmap(inputStream, CanvasAdapter.dpi / 160, DEFAULT_SIZE, 0, 0, 100);
|
||||
}
|
||||
}
|
||||
|
||||
public AndroidSvgBitmap(InputStream inputStream) throws IOException {
|
||||
super(getResourceBitmapImpl(inputStream));
|
||||
}
|
||||
}
|
||||
|
@ -28,38 +28,62 @@ import java.net.URI;
|
||||
|
||||
public class AwtSvgBitmap extends AwtBitmap {
|
||||
/**
|
||||
* Default size is 20x20px.
|
||||
* Default size is 20x20px (400px).
|
||||
*/
|
||||
public static float DEFAULT_SIZE = 400f;
|
||||
|
||||
private static BufferedImage getResourceBitmap(InputStream inputStream) throws IOException {
|
||||
synchronized (SVGCache.getSVGUniverse()) {
|
||||
try {
|
||||
URI uri = SVGCache.getSVGUniverse().loadSVG(inputStream, Integer.toString(inputStream.hashCode()));
|
||||
SVGDiagram diagram = SVGCache.getSVGUniverse().getDiagram(uri);
|
||||
public static BufferedImage getResourceBitmap(InputStream inputStream, float scaleFactor, float defaultSize, int width, int height, int percent) throws IOException {
|
||||
try {
|
||||
URI uri = SVGCache.getSVGUniverse().loadSVG(inputStream, Integer.toString(inputStream.hashCode()));
|
||||
SVGDiagram diagram = SVGCache.getSVGUniverse().getDiagram(uri);
|
||||
|
||||
float scaleFactor = CanvasAdapter.dpi / 240;
|
||||
double scale = scaleFactor / Math.sqrt((diagram.getHeight() * diagram.getWidth()) / DEFAULT_SIZE);
|
||||
double scale = scaleFactor / Math.sqrt((diagram.getHeight() * diagram.getWidth()) / defaultSize);
|
||||
|
||||
float bitmapWidth = (float) (diagram.getWidth() * scale);
|
||||
float bitmapHeight = (float) (diagram.getHeight() * scale);
|
||||
float bitmapWidth = (float) (diagram.getWidth() * scale);
|
||||
float bitmapHeight = (float) (diagram.getHeight() * scale);
|
||||
|
||||
SVGIcon icon = new SVGIcon();
|
||||
icon.setAntiAlias(true);
|
||||
icon.setPreferredSize(new Dimension((int) bitmapWidth, (int) bitmapHeight));
|
||||
icon.setScaleToFit(true);
|
||||
icon.setSvgURI(uri);
|
||||
BufferedImage bufferedImage = new BufferedImage(icon.getIconWidth(), icon.getIconHeight(), BufferedImage.TYPE_INT_ARGB);
|
||||
icon.paintIcon(null, bufferedImage.createGraphics(), 0, 0);
|
||||
float aspectRatio = diagram.getWidth() / diagram.getHeight();
|
||||
|
||||
return bufferedImage;
|
||||
} catch (Exception e) {
|
||||
throw new IOException(e);
|
||||
if (width != 0 && height != 0) {
|
||||
// both width and height set, override any other setting
|
||||
bitmapWidth = width;
|
||||
bitmapHeight = height;
|
||||
} else if (width == 0 && height != 0) {
|
||||
// only width set, calculate from aspect ratio
|
||||
bitmapWidth = height * aspectRatio;
|
||||
bitmapHeight = height;
|
||||
} else if (width != 0 && height == 0) {
|
||||
// only height set, calculate from aspect ratio
|
||||
bitmapHeight = width / aspectRatio;
|
||||
bitmapWidth = width;
|
||||
}
|
||||
|
||||
if (percent != 100) {
|
||||
bitmapWidth *= percent / 100f;
|
||||
bitmapHeight *= percent / 100f;
|
||||
}
|
||||
|
||||
SVGIcon icon = new SVGIcon();
|
||||
icon.setAntiAlias(true);
|
||||
icon.setPreferredSize(new Dimension((int) bitmapWidth, (int) bitmapHeight));
|
||||
icon.setScaleToFit(true);
|
||||
icon.setSvgURI(uri);
|
||||
BufferedImage bufferedImage = new BufferedImage(icon.getIconWidth(), icon.getIconHeight(), BufferedImage.TYPE_INT_ARGB);
|
||||
icon.paintIcon(null, bufferedImage.createGraphics(), 0, 0);
|
||||
|
||||
return bufferedImage;
|
||||
} catch (Exception e) {
|
||||
throw new IOException(e);
|
||||
}
|
||||
}
|
||||
|
||||
AwtSvgBitmap(InputStream inputStream) throws IOException {
|
||||
super(getResourceBitmap(inputStream));
|
||||
private static BufferedImage getResourceBitmapImpl(InputStream inputStream) throws IOException {
|
||||
synchronized (SVGCache.getSVGUniverse()) {
|
||||
return getResourceBitmap(inputStream, CanvasAdapter.dpi / 240, DEFAULT_SIZE, 0, 0, 100);
|
||||
}
|
||||
}
|
||||
|
||||
public AwtSvgBitmap(InputStream inputStream) throws IOException {
|
||||
super(getResourceBitmapImpl(inputStream));
|
||||
}
|
||||
}
|
||||
|
@ -33,7 +33,10 @@ import svg.SVGRenderer;
|
||||
public class IosSvgBitmap extends IosBitmap {
|
||||
private static final Logger log = LoggerFactory.getLogger(IosSvgBitmap.class);
|
||||
|
||||
private static final float DEFAULT_SIZE = 400f;
|
||||
/**
|
||||
* Default size is 20x20px (400px).
|
||||
*/
|
||||
public static float DEFAULT_SIZE = 400f;
|
||||
|
||||
private static String getStringFromInputStream(InputStream is) {
|
||||
StringBuilder sb = new StringBuilder();
|
||||
@ -52,21 +55,45 @@ public class IosSvgBitmap extends IosBitmap {
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
private static UIImage getUIImage(InputStream inputStream) {
|
||||
public static UIImage getResourceBitmap(InputStream inputStream, float scaleFactor, float defaultSize, int width, int height, int percent) {
|
||||
String svg = getStringFromInputStream(inputStream);
|
||||
SVGRenderer renderer = new SVGRenderer(svg);
|
||||
CGRect viewRect = renderer.getViewRect();
|
||||
|
||||
float scaleFactor = CanvasAdapter.dpi / 240;
|
||||
double scale = scaleFactor / Math.sqrt((viewRect.getHeight() * viewRect.getWidth()) / DEFAULT_SIZE);
|
||||
double scale = scaleFactor / Math.sqrt((viewRect.getHeight() * viewRect.getWidth()) / defaultSize);
|
||||
|
||||
float bitmapWidth = (float) (viewRect.getWidth() * scale);
|
||||
float bitmapHeight = (float) (viewRect.getHeight() * scale);
|
||||
|
||||
float aspectRatio = (float) (viewRect.getWidth() / viewRect.getHeight());
|
||||
|
||||
if (width != 0 && height != 0) {
|
||||
// both width and height set, override any other setting
|
||||
bitmapWidth = width;
|
||||
bitmapHeight = height;
|
||||
} else if (width == 0 && height != 0) {
|
||||
// only width set, calculate from aspect ratio
|
||||
bitmapWidth = height * aspectRatio;
|
||||
bitmapHeight = height;
|
||||
} else if (width != 0 && height == 0) {
|
||||
// only height set, calculate from aspect ratio
|
||||
bitmapHeight = width / aspectRatio;
|
||||
bitmapWidth = width;
|
||||
}
|
||||
|
||||
if (percent != 100) {
|
||||
bitmapWidth *= percent / 100f;
|
||||
bitmapHeight *= percent / 100f;
|
||||
}
|
||||
|
||||
return renderer.asImageWithSize(new CGSize(bitmapWidth, bitmapHeight), 1);
|
||||
}
|
||||
|
||||
private static UIImage getResourceBitmapImpl(InputStream inputStream) {
|
||||
return getResourceBitmap(inputStream, CanvasAdapter.dpi / 240, DEFAULT_SIZE, 0, 0, 100);
|
||||
}
|
||||
|
||||
public IosSvgBitmap(InputStream inputStream) throws IOException {
|
||||
super(getUIImage(inputStream));
|
||||
super(getResourceBitmapImpl(inputStream));
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user