- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 java 程序,可以读取部分 postscript 文件以生成 postscript 和 PDF 报告。
如何创建要包含在报告中的彩色图像(例如 Logo 或横幅)资源?
已经有一个现有的颜色 Logo 作为 postscript 文件。需要弄清楚如何为新图像创建此类文件。图像可以是以下任意格式:JPG、SVG 或 PNG。
作为一种解决方法,我已经尝试改进将 JPG 转换为 8 位分辨率的 postscript 资源的 java 应用程序。但不知道如何将其转换为24位分辨率的彩色Postscript资源。
我尝试过许多将图像转换为“.PS”或“.EPS”文件的转换器,但它们都没有类似的代码,因此无法成功集成到java应用程序中(请参阅提供的postscript代码)。
以下颜色 Logo 的后记代码已显示在其中一份报告中。 java程序有什么方法可以读取图像(JPG或SVG)并将其转换为类似的代码:
/UniversityLogoResource {
newpath
0 84.2 moveto
474.8 84.2 lineto
474.8 0 lineto
0 0 lineto
0 84.2 lineto
closepath
1 1 1 setrgbcolor
fill
newpath
8.688 74.76 moveto
18.592 74.69 28.498 74.75 38.402 74.73 curveto
52.57 74.726 66.738 74.738 80.906 74.724 curveto
80.902 53.286 80.904 31.848 80.906 10.408 curveto
80.89 9.728 80.964 9.04 80.852 8.362 curveto
59.504 8.326 38.156 8.358 16.806 8.348 curveto
14.144 8.324 11.48 8.394 8.818 8.31 curveto
8.846 29.606 8.82 50.902 8.836 72.198 curveto
8.858 73.044 8.872 73.898 8.694 74.73 curveto
8.688 74.76 lineto
closepath
0 0.565 0.749 setrgbcolor
fill
newpath
8.694 74.73 moveto
8.872 73.898 8.858 73.044 8.836 72.198 curveto
8.82 50.902 8.846 29.606 8.818 8.31 curveto
8.636 8.506 8.55 8.736 8.564 9 curveto
8.568 30.598 8.566 52.196 8.564 73.794 curveto
8.584 74.11 8.626 74.422 8.694 74.73 curveto
closepath
0.275 0.608 0.69 setrgbcolor
fill
}
以下代码(替代解决方案)尝试将图像转换为 24 位分辨率的字节数组。是否可以将彩色图像转换为字节数组?:
private byte[] getImageBytesAt24BitsResolution() {
int[] pixels = new int[realWidth * realHeight];
PixelGrabber pixGrab = new PixelGrabber(image, 0, 0, realWidth, realHeight, pixels, 0, realWidth);
try {
pixGrab.grabPixels();
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
int size = realWidth * realHeight;
byte[] data = new byte[size];
int datumPos = 0;
for (int y = 0; y < realHeight; y++) {
for (int x = 0; x < realWidth; x++) {
Color color = new Color(pixels[x + realWidth * y]);
int rgb = color.getRGB();
ColorModel cm = image.getColorModel();
Object pixel = cm.getDataElements(rgb, null);
data[datumPos] = ((byte[]) pixel)[0];
datumPos++;
}
}
return data;
}
以下java代码使用在上述方法getImageBytesAt24BitsResolution()
中创建的字节数组imageBytes
创建postscript资源文件:
byte[] rleBytes = PSDecoders.rleEncode(imageBytes);
// String[] asciiBytes = PSDecoders.ascii85Encode(rleBytes);
String[] asciiBytes = PSDecoders.hexEncode(rleBytes);
StringBuffer sb = new StringBuffer();
sb.append("%===============================================================\n");
sb.append("%%BeginResource: file " + (new File(mFileName).getName()) + " 1 0\n");
sb.append("/" + postscriptID +".form\n");
sb.append("<<\n");
sb.append("/FormType 1\n");
sb.append("/BBox[0 0 "+((int)Math.ceil(endWidth))+" "+((int)Math.ceil(endHeight))+"]\n");
sb.append("/Matrix[1 0 0 1 0 0]\n");
sb.append("/PaintProc{pop\n");
sb.append("/DeviceGray setcolorspace gsave\n");
sb.append(doubleFormat(endWidth)+" "+doubleFormat(endHeight)+" scale\n");
sb.append("<<\n");
sb.append("/Interpolate true\n");
sb.append("/ImageType 1\n");
sb.append("/Width "+realWidth+"\n");
sb.append("/Height "+realHeight+"\n");
sb.append("/ImageMatrix["+realWidth+" 0 0 -"+realHeight+" 0 "+realHeight+"]\n");
sb.append("/BitsPerComponent "+resolution.getBits()+"\n");
sb.append("/Decode[0 1]");
sb.append("/DataSource\n<");
for(String line : asciiBytes) {
sb.append(line);
sb.append("\n");
}
sb.append(">\n/RunLengthDecode filter\n>>\n");
sb.append("image grestore}\n>> def\n");
sb.append("% -- proc call\n");
sb.append("/" + postscriptID +" { % x y\n");
sb.append("gsave translate "+postscriptID+".form execform grestore\n");
sb.append("} def\n");
sb.append("%%EndResource\n");
最佳答案
您无法在 PostScript 程序中嵌入 SVG 或 PNG 图像,因为 PostScript 不支持这些格式。您需要首先将它们解码为简单的光栅位图。
您引用的 Logo 未使用图像。它通过绘制一系列形状并填充它们来绘制 Logo 。它是 vector 描述而不是图像。
您可以将光栅图像转换为一系列矩形填充;依次获取每个图像样本,计算其在输出设备上的位置(和大小),在给定位置绘制一个大小相同的矩形,并用样本的颜色值填充它。这将产生一个绝对巨大的输出文件,并且渲染速度非常慢。
更好的方法是将图像数据作为图像包含在内。要在 PostScript 中绘制图像,请使用 image
运算符,它有两种形式。我建议您使用运算符的字典形式。图像运算符在 PostScript 语言引用手册(第 3 版)第 607 页上定义,并在同一引用文献的第 288 页开始的第 4.10 节中详细解释。
基本上,您需要使用许多参数(宽度、高度、BitsPerComponent)设置图像字典、用于读取图像数据的数据源(通常是当前文件)以及定义最终图像的大小和位置的 ImageMatrix用户空间。现在,对于 JPEG 图像,您可以简单地插入压缩数据流并使用 DCTDecode 过滤器指定数据源。其他图像格式需要进行解码,并将图像数据作为原始样本插入,或者,如果需要考虑大小,则需要使用可用的 PostScript 过滤器之一(例如 Flate)和数据源提供的适当解码过滤器进行压缩。
作为示例,这是在级别 2 中定义的传统火鸡图像:
%!
50 10 translate % Locate lower-left corner of square
/DrawTurkey {
0 setgray
<<
/ImageType 1
/Width 24
/Height 23
/ImageMatrix [.24 0 0 .23 0 0]
/BitsPerComponent 1
/Decode [1 0]
/MultipleDataSources false
/DataSource < 003B00 002700 002480 0E4940
114920 14B220 3CB650 75FE88
17FF8C 175F14 1C07E2 3803C4
703182 F8EDFC B2BBC2 BB6F84
31BFC2 18EA3C 0E3E00 07FC00
03F800 1E1800 1FF800 >
>> imagemask
} def
% Draw the turkey upright
24 2 div 23 2 div [.24 0 0 .23 0 0] transform
exch (centre at x = ) print == ( y = ) print ==
0.5 setgray
0 0 100 100 rectfill
0 1 0 setrgbcolor
0 0 moveto 0 100 lineto stroke
0 0 1 setrgbcolor
0 0 moveto 100 0 lineto stroke
1 0 0 setrgbcolor
0 0 moveto 100 100 lineto stroke
DrawTurkey
showpage
请注意,该程序将图像数据嵌入十六进制字符串中,如果您的图像数据超过 64Kb,您将无法执行此操作。
关于java - 如何将图像转换为 postscript 形状,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57796968/
我是 TensorFlow 菜鸟。我已经从 deeppose 的开源实现中训练了一个 TensorFlow 模型,现在必须针对一组新图像运行该模型。 该模型是在大小为 100 * 100 的图像上训练
我正在尝试以这种方式设置节点的大小: controller[shape=circle,width=.5,label="Controller",style=filled,fillcolor="#8EC1
是否有 VBA 代码可以在选择的每个单元格周围添加文本框。文本框应该是单元格的大小(类似于边框)? 最佳答案 您可以使用 .AddTextbox方法。循环遍历您选择的单元格,并使用单元格的尺寸属性来设
我有一个变量 a尺寸 (1, 5) 我想“平铺”的次数与我的小批量的大小一样多。例如,如果小批量大小为 32,那么我想构造一个张量 c维度为 (32, 5),其中每一行的值与原始 (1, 5) 变量
我在使用 javaFX 时遇到问题。我想每 1000 毫秒在应用程序窗口中显示一次时间。 public class Main extends Application { StackPane root
所以我目前正在创建这个 API。这个登录类应该只创建一个场景,其中包含制作 GUI 所需的所有框。我遇到的问题是,单击时我的形状不会执行任何操作。我有事件监听器,但它不起作用。 import
我正在用 python turtle 画一些东西,我使用了形状函数,但是形状 overdraw 了它们之前的其他形状(我可以看到形状在移动),并且我只得到了最后一个形状: `up() goto(-20
我正在读取多个 .csv 文件作为具有相同形状的 panda DataFrame。对于某些索引,某些值为零,因此我想选择具有相同形状的每个索引的值,并为相同的索引放置零值并删除零以成为相同的形状: a
我有一个简单的二维网格,格式为 myGrid[x,y] 我正在尝试找到一种方法来找到围绕选定网格的周长,这样我就有了一个可供选择的形状。 这是我的意思的一个例子: 这里的想法是找到所有相关的“角”,也
我有一个网络层,用于调用多个端点。我想减少重复代码的数量,并认为也许我可以将响应模型作为端点的一部分传递。 这个想法是不需要多个仅因响应而不同的函数,我可以调用我的网络层并根据路径进行设置。 我看到的
我正在创建一个自定义 ImageView,它将我的图像裁剪成六边形并添加边框。我想知道我的方法是否正确,或者我是否以错误的方式这样做。有很多自定义库已经在执行此操作,但开箱即用的库中没有一个具有我正在
我正在编写一些代码,这些代码需要识别一些基于节点云的相当基本的几何图形。我会对检测感兴趣: 板(简单有界平面) 圆柱体(两个节点循环) 半圆柱(圆弧+直线+圆弧+直线) 圆顶(n*loop+top n
我有这个形状: http://screencast.com/t/9UUhAXT5Wu 但边界在截止点处没有跟随它 - 我该如何解决? 这是我当前 View 的代码: self.view.backgro
我现在脑震荡,所以我想问一个非常简单的问题。 目前,我正在尝试打印出这样的开头 当输入为 7 时,输出为 * ** * ** * ** * 这里是我的代码,它打印 14 次而不是 7 次,或者当我输入
我想生成如下设计。计划选项卡顶部的"new"。我使用的属性适用于 chrome 和 mozilla,但在 Edge 中出现故障。 以下是我在 chrome 中应用的样式: a.subnav__item
我想要一个带有两种颜色边框轮廓的 shape 元素。我可以使用 solid 元素做一个单一的颜色轮廓,但这只允许我画一条线。我尝试在我的形状中使用两个 stroke 元素,但这也不起作用。 有没有办法
我需要为屏幕上的形状着色任何我想要的颜色。我目前正在尝试使用 UIImage 来执行此操作,我想根据自己的需要重新着色。据我所知,执行此操作的唯一方法是获取 UIImage 的各个像素,这需要更多我想
因此,经过多年的 OOP,我从我的一门大学类(class)中得到了一个非常简单的家庭作业,以实现一个简单的面向对象的结构。 要求的设计: 实现面向对象的解决方案以创建以下形状: 椭圆、圆形、正方形、矩
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 5 年前。 Improve this qu
我想知道是否可以使用类似于以下的 div 制作复杂的形状: 它基本上是一个四 Angular 向内收缩的圆 Angular 正方形。目标是使用背景图像来填充它。我可以使用具有以下 SVG 路径的剪辑蒙
我是一名优秀的程序员,十分优秀!