aboutsummaryrefslogtreecommitdiffstats
path: root/src/java
diff options
context:
space:
mode:
Diffstat (limited to 'src/java')
-rw-r--r--src/java/org/apache/fop/svg/PDFGraphics2D.java65
1 files changed, 21 insertions, 44 deletions
diff --git a/src/java/org/apache/fop/svg/PDFGraphics2D.java b/src/java/org/apache/fop/svg/PDFGraphics2D.java
index 241f0a316..d0bbaf9fe 100644
--- a/src/java/org/apache/fop/svg/PDFGraphics2D.java
+++ b/src/java/org/apache/fop/svg/PDFGraphics2D.java
@@ -57,6 +57,7 @@ import org.apache.fop.pdf.PDFColorSpace;
import org.apache.fop.pdf.PDFColor;
import org.apache.fop.pdf.PDFState;
import org.apache.fop.pdf.PDFNumber;
+import org.apache.fop.pdf.PDFText;
import org.apache.fop.pdf.PDFXObject;
import org.apache.fop.pdf.PDFPattern;
import org.apache.fop.pdf.PDFDocument;
@@ -317,10 +318,11 @@ public class PDFGraphics2D extends AbstractGraphics2D {
if (linkType != PDFLink.EXTERNAL) {
String pdfdest = "/FitR " + dest;
- resourceContext.addAnnotation(pdfDoc.makeLink(rect, pageRef, pdfdest));
+ resourceContext.addAnnotation(
+ pdfDoc.getFactory().makeLink(rect, pageRef, pdfdest));
} else {
- resourceContext.addAnnotation(pdfDoc.makeLink(rect,
- dest, linkType, 0));
+ resourceContext.addAnnotation(
+ pdfDoc.getFactory().makeLink(rect, dest, linkType, 0));
}
}
}
@@ -673,7 +675,8 @@ public class PDFGraphics2D extends AbstractGraphics2D {
if (c.getAlpha() != 255) {
Map vals = new java.util.HashMap();
vals.put(PDFGState.GSTATE_ALPHA_STROKE, new Float(c.getAlpha() / 255f));
- PDFGState gstate = pdfDoc.makeGState(vals, graphicsState.getGState());
+ PDFGState gstate = pdfDoc.getFactory().makeGState(
+ vals, graphicsState.getGState());
//gstate.setAlpha(c.getAlpha() / 255f, false);
resourceContext.addGState(gstate);
currentStream.write("/" + gstate.getName() + " gs\n");
@@ -917,7 +920,8 @@ public class PDFGraphics2D extends AbstractGraphics2D {
}
PDFColorSpace aColorSpace = new PDFColorSpace(PDFColorSpace.DEVICE_RGB);
- PDFPattern myPat = pdfDoc.createGradient(resourceContext, false, aColorSpace,
+ PDFPattern myPat = pdfDoc.getFactory().makeGradient(
+ resourceContext, false, aColorSpace,
someColors, theBounds, theCoords);
currentStream.write(myPat.getColorSpaceOut(fill));
@@ -964,7 +968,8 @@ public class PDFGraphics2D extends AbstractGraphics2D {
theBounds.add(new Double(offset));
}
PDFColorSpace colSpace = new PDFColorSpace(PDFColorSpace.DEVICE_RGB);
- PDFPattern myPat = pdfDoc.createGradient(resourceContext, true, colSpace,
+ PDFPattern myPat = pdfDoc.getFactory().makeGradient(
+ resourceContext, true, colSpace,
someColors, theBounds, theCoords);
currentStream.write(myPat.getColorSpaceOut(fill));
@@ -981,8 +986,8 @@ public class PDFGraphics2D extends AbstractGraphics2D {
FontInfo fi = new FontInfo();
FontSetup.setup(fi, null);
- PDFResources res = pdfDoc.makeResources();
- PDFResourceContext context = new PDFResourceContext(0, pdfDoc, res);
+ PDFResources res = pdfDoc.getFactory().makeResources();
+ PDFResourceContext context = new PDFResourceContext(res);
PDFGraphics2D pattGraphic = new PDFGraphics2D(textAsShapes, fi,
pdfDoc, context, pageRef,
"", 0);
@@ -1024,7 +1029,8 @@ public class PDFGraphics2D extends AbstractGraphics2D {
FontSetup.addToResources(pdfDoc, res, fi);
- PDFPattern myPat = pdfDoc.makePattern(resourceContext, 1, res, 1, 1, bbox,
+ PDFPattern myPat = pdfDoc.getFactory().makePattern(
+ resourceContext, 1, res, 1, 1, bbox,
rect.getWidth(), rect.getHeight(),
translate, null, pattStream.getBuffer());
@@ -1032,7 +1038,7 @@ public class PDFGraphics2D extends AbstractGraphics2D {
PDFAnnotList annots = context.getAnnotations();
if (annots != null) {
- this.pdfDoc.addAnnotList(annots);
+ this.pdfDoc.addObject(annots);
}
if (outputStream != null) {
@@ -1236,7 +1242,8 @@ public class PDFGraphics2D extends AbstractGraphics2D {
if (salpha != 255) {
Map vals = new java.util.HashMap();
vals.put(PDFGState.GSTATE_ALPHA_NONSTROKE, new Float(salpha / 255f));
- PDFGState gstate = pdfDoc.makeGState(vals, graphicsState.getGState());
+ PDFGState gstate = pdfDoc.getFactory().makeGState(
+ vals, graphicsState.getGState());
resourceContext.addGState(gstate);
currentStream.write("/" + gstate.getName() + " gs\n");
}
@@ -1300,7 +1307,7 @@ public class PDFGraphics2D extends AbstractGraphics2D {
currentStream.write(ch);
}
} else {
- currentStream.write(getUnicodeString(ch));
+ currentStream.write(PDFText.toUnicodeHex(ch));
}
if (kerningAvailable && (i + 1) < l) {
@@ -1333,37 +1340,6 @@ public class PDFGraphics2D extends AbstractGraphics2D {
}
/**
- * Convert a char to a multibyte hex representation
- */
- private String getUnicodeString(char c) {
-
- StringBuffer buf = new StringBuffer(4);
- byte[] uniBytes = null;
- try {
- char[] a = {
- c
- };
- uniBytes = new String(a).getBytes("UnicodeBigUnmarked");
- } catch (Exception e) {
- // This should never fail
- }
-
- for (int i = 0; i < uniBytes.length; i++) {
- int b = (uniBytes[i] < 0) ? (int)(256 + uniBytes[i])
- : (int)uniBytes[i];
-
- String hexString = Integer.toHexString(b);
- if (hexString.length() == 1) {
- buf = buf.append("0" + hexString);
- } else {
- buf = buf.append(hexString);
- }
- }
-
- return buf.toString();
- }
-
- /**
* Renders the text of the specified iterator, using the
* <code>Graphics2D</code> context's current <code>Paint</code>. The
* iterator must specify a font
@@ -1489,7 +1465,8 @@ public class PDFGraphics2D extends AbstractGraphics2D {
if (c.getAlpha() != 255) {
Map vals = new java.util.HashMap();
vals.put(PDFGState.GSTATE_ALPHA_NONSTROKE, new Float(c.getAlpha() / 255f));
- PDFGState gstate = pdfDoc.makeGState(vals, graphicsState.getGState());
+ PDFGState gstate = pdfDoc.getFactory().makeGState(
+ vals, graphicsState.getGState());
resourceContext.addGState(gstate);
currentStream.write("/" + gstate.getName() + " gs\n");
}