summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorkitfox2014-02-06 10:41:11 +0100
committerkitfox2014-02-06 10:41:11 +0100
commitd0842693d5d9b93d73146bc981268a274e6a4765 (patch)
tree49e565394750e6293c214ef8a357c341496dd67f /src
parentFixing SVGSALAMANDER-31. Can now animate an interpolation between two paths ... (diff)
downloadsvg-salamander-core-d0842693d5d9b93d73146bc981268a274e6a4765.tar.gz
svg-salamander-core-d0842693d5d9b93d73146bc981268a274e6a4765.tar.xz
svg-salamander-core-d0842693d5d9b93d73146bc981268a274e6a4765.zip
Fixing SVGSALAMANDER-32. Adding a variety of automatic scaling options to SVGIcon and SVGPanel.
git-svn-id: https://svn.java.net/svn/svgsalamander~svn/trunk/svg-core@166 7dc7fa77-23fb-e6ad-8e2e-c86bd48ed22b
Diffstat (limited to 'src')
-rw-r--r--src/main/java/com/kitfox/svg/app/beans/SVGIcon.java86
-rw-r--r--src/main/java/com/kitfox/svg/app/beans/SVGPanel.java88
2 files changed, 149 insertions, 25 deletions
diff --git a/src/main/java/com/kitfox/svg/app/beans/SVGIcon.java b/src/main/java/com/kitfox/svg/app/beans/SVGIcon.java
index 389b375..30380e5 100644
--- a/src/main/java/com/kitfox/svg/app/beans/SVGIcon.java
+++ b/src/main/java/com/kitfox/svg/app/beans/SVGIcon.java
@@ -50,6 +50,8 @@ import javax.swing.*;
public class SVGIcon implements Icon
{
public static final long serialVersionUID = 1;
+
+ public static final String PROP_AUTOSIZE = "PROP_AUTOSIZE";
private PropertyChangeSupport changes = new PropertyChangeSupport(this);
@@ -65,8 +67,15 @@ public class SVGIcon implements Icon
// private String svgPath;
URI svgURI;
- private boolean scaleToFit;
+// private boolean scaleToFit;
AffineTransform scaleXform = new AffineTransform();
+
+ public static final int AUTOSIZE_NONE = 0;
+ public static final int AUTOSIZE_HORIZ = 1;
+ public static final int AUTOSIZE_VERT = 2;
+ public static final int AUTOSIZE_BESTFIT = 3;
+ public static final int AUTOSIZE_STRETCH = 4;
+ private int autosize = AUTOSIZE_NONE;
// Dimension preferredSize = new Dimension(100, 100);
Dimension preferredSize;
@@ -91,7 +100,9 @@ public class SVGIcon implements Icon
*/
public int getIconHeight()
{
- if (scaleToFit && preferredSize != null)
+ if (preferredSize != null &&
+ (autosize == AUTOSIZE_VERT || autosize == AUTOSIZE_STRETCH
+ || autosize == AUTOSIZE_BESTFIT))
{
return preferredSize.height;
}
@@ -109,7 +120,9 @@ public class SVGIcon implements Icon
*/
public int getIconWidth()
{
- if (scaleToFit && preferredSize != null)
+ if (preferredSize != null &&
+ (autosize == AUTOSIZE_HORIZ || autosize == AUTOSIZE_STRETCH
+ || autosize == AUTOSIZE_BESTFIT))
{
return preferredSize.width;
}
@@ -172,7 +185,7 @@ public class SVGIcon implements Icon
- if (!scaleToFit)
+ if (autosize == AUTOSIZE_NONE)
{
try
{
@@ -209,10 +222,34 @@ public class SVGIcon implements Icon
// g.setClip(0, 0, width, height);
- final Rectangle2D.Double rect = new Rectangle2D.Double();
- diagram.getViewRect(rect);
+// final Rectangle2D.Double rect = new Rectangle2D.Double();
+// diagram.getViewRect(rect);
+//
+// scaleXform.setToScale(width / rect.width, height / rect.height);
+ double diaWidth = diagram.getWidth();
+ double diaHeight = diagram.getHeight();
- scaleXform.setToScale(width / rect.width, height / rect.height);
+ double scaleW = 1;
+ double scaleH = 1;
+ if (autosize == AUTOSIZE_BESTFIT)
+ {
+ scaleW = scaleH = (height / diaHeight < width / diaWidth)
+ ? height / diaHeight : width / diaWidth;
+ }
+ else if (autosize == AUTOSIZE_HORIZ)
+ {
+ scaleW = scaleH = width / diaWidth;
+ }
+ else if (autosize == AUTOSIZE_VERT)
+ {
+ scaleW = scaleH = height / diaHeight;
+ }
+ else if (autosize == AUTOSIZE_STRETCH)
+ {
+ scaleW = width / diaWidth;
+ scaleH = height / diaHeight;
+ }
+ scaleXform.setToScale(scaleW, scaleH);
AffineTransform oldXform = g.getTransform();
g.transform(scaleXform);
@@ -314,17 +351,24 @@ public class SVGIcon implements Icon
/**
* If this SVG document has a viewbox, if scaleToFit is set, will scale the viewbox to match the
* preferred size of this icon
+ * @deprecated
+ * @return
*/
public boolean isScaleToFit()
{
- return scaleToFit;
+ return autosize == AUTOSIZE_STRETCH;
}
+ /**
+ * @deprecated
+ * @return
+ */
public void setScaleToFit(boolean scaleToFit)
{
- boolean old = this.scaleToFit;
- this.scaleToFit = scaleToFit;
- changes.firePropertyChange("scaleToFit", old, scaleToFit);
+ setAutosize(AUTOSIZE_STRETCH);
+// boolean old = this.scaleToFit;
+// this.scaleToFit = scaleToFit;
+// firePropertyChange("scaleToFit", old, scaleToFit);
}
public Dimension getPreferredSize()
@@ -428,5 +472,23 @@ public class SVGIcon implements Icon
{
this.clipToViewbox = clipToViewbox;
}
-
+
+ /**
+ * @return the autosize
+ */
+ public int getAutosize()
+ {
+ return autosize;
+ }
+
+ /**
+ * @param autosize the autosize to set
+ */
+ public void setAutosize(int autosize)
+ {
+ int oldAutosize = this.autosize;
+ this.autosize = autosize;
+ changes.firePropertyChange(PROP_AUTOSIZE, oldAutosize, autosize);
+ }
+
}
diff --git a/src/main/java/com/kitfox/svg/app/beans/SVGPanel.java b/src/main/java/com/kitfox/svg/app/beans/SVGPanel.java
index 5682b74..e81f519 100644
--- a/src/main/java/com/kitfox/svg/app/beans/SVGPanel.java
+++ b/src/main/java/com/kitfox/svg/app/beans/SVGPanel.java
@@ -49,7 +49,7 @@ import javax.swing.*;
public class SVGPanel extends JPanel
{
public static final long serialVersionUID = 1;
-
+ public static final String PROP_AUTOSIZE = "PROP_AUTOSIZE";
SVGUniverse svgUniverse = SVGCache.getSVGUniverse();
@@ -58,8 +58,15 @@ public class SVGPanel extends JPanel
// private String svgPath;
URI svgURI;
- private boolean scaleToFit;
+// private boolean scaleToFit;
AffineTransform scaleXform = new AffineTransform();
+
+ public static final int AUTOSIZE_NONE = 0;
+ public static final int AUTOSIZE_HORIZ = 1;
+ public static final int AUTOSIZE_VERT = 2;
+ public static final int AUTOSIZE_BESTFIT = 3;
+ public static final int AUTOSIZE_STRETCH = 4;
+ private int autosize = AUTOSIZE_NONE;
/** Creates new form SVGIcon */
public SVGPanel()
@@ -69,7 +76,8 @@ public class SVGPanel extends JPanel
public int getSVGHeight()
{
- if (scaleToFit)
+ if (autosize == AUTOSIZE_VERT || autosize == AUTOSIZE_STRETCH
+ || autosize == AUTOSIZE_BESTFIT)
{
return getPreferredSize().height;
}
@@ -84,7 +92,8 @@ public class SVGPanel extends JPanel
public int getSVGWidth()
{
- if (scaleToFit)
+ if (autosize == AUTOSIZE_HORIZ || autosize == AUTOSIZE_STRETCH
+ || autosize == AUTOSIZE_BESTFIT)
{
return getPreferredSize().width;
}
@@ -118,7 +127,7 @@ public class SVGPanel extends JPanel
return;
}
- if (!scaleToFit)
+ if (autosize == AUTOSIZE_NONE)
{
try
{
@@ -136,10 +145,33 @@ public class SVGPanel extends JPanel
final int width = dim.width;
final int height = dim.height;
- final Rectangle2D.Double rect = new Rectangle2D.Double();
- diagram.getViewRect(rect);
+// final Rectangle2D.Double rect = new Rectangle2D.Double();
+// diagram.getViewRect(rect);
- scaleXform.setToScale(width / rect.width, height / rect.height);
+ double diaWidth = diagram.getWidth();
+ double diaHeight = diagram.getHeight();
+
+ double scaleW = 1;
+ double scaleH = 1;
+ if (autosize == AUTOSIZE_BESTFIT)
+ {
+ scaleW = scaleH = (height / diaHeight < width / diaWidth)
+ ? height / diaHeight : width / diaWidth;
+ }
+ else if (autosize == AUTOSIZE_HORIZ)
+ {
+ scaleW = scaleH = width / diaWidth;
+ }
+ else if (autosize == AUTOSIZE_VERT)
+ {
+ scaleW = scaleH = height / diaHeight;
+ }
+ else if (autosize == AUTOSIZE_STRETCH)
+ {
+ scaleW = width / diaWidth;
+ scaleH = height / diaHeight;
+ }
+ scaleXform.setToScale(scaleW, scaleH);
AffineTransform oldXform = g.getTransform();
g.transform(scaleXform);
@@ -207,16 +239,27 @@ public class SVGPanel extends JPanel
}
}
+ /**
+ * If this SVG document has a viewbox, if scaleToFit is set, will scale the viewbox to match the
+ * preferred size of this icon
+ * @deprecated
+ * @return
+ */
public boolean isScaleToFit()
{
- return scaleToFit;
+ return autosize == AUTOSIZE_STRETCH;
}
-
+
+ /**
+ * @deprecated
+ * @return
+ */
public void setScaleToFit(boolean scaleToFit)
{
- boolean old = this.scaleToFit;
- this.scaleToFit = scaleToFit;
- firePropertyChange("scaleToFit", old, scaleToFit);
+ setAutosize(AUTOSIZE_STRETCH);
+// boolean old = this.scaleToFit;
+// this.scaleToFit = scaleToFit;
+// firePropertyChange("scaleToFit", old, scaleToFit);
}
/**
@@ -254,6 +297,24 @@ public class SVGPanel extends JPanel
this.antiAlias = antiAlias;
firePropertyChange("antiAlias", old, antiAlias);
}
+
+ /**
+ * @return the autosize
+ */
+ public int getAutosize()
+ {
+ return autosize;
+ }
+
+ /**
+ * @param autosize the autosize to set
+ */
+ public void setAutosize(int autosize)
+ {
+ int oldAutosize = this.autosize;
+ this.autosize = autosize;
+ firePropertyChange(PROP_AUTOSIZE, oldAutosize, autosize);
+ }
/** This method is called from within the constructor to
* initialize the form.
@@ -272,5 +333,6 @@ public class SVGPanel extends JPanel
// Variables declaration - do not modify//GEN-BEGIN:variables
// End of variables declaration//GEN-END:variables
+
}