我需要在16位深度和颜色模式下使用扫描仪,所以我修改了python-imaging-sane(不支持16位深度的RGB tiff)从扫描仪(epson v500)接收图像Python字符串。
这是我用来将数据从扫描器发送到python字符串的修改过的函数:
#define READSIZE 32768
static PyObject *
SaneDev_read(SaneDevObject *self, PyObject *args)
{
SANE_Status st;
unsigned char c_buf[READSIZE];
SANE_Int len, maxlen;
maxlen = READSIZE;
if (!PyArg_ParseTuple(args, ""))
{
return NULL;
}
st = (int) sane_read(self->h, (SANE_Byte *) c_buf, maxlen, &len);
return Py_BuildValue("is#", st, c_buf, len);
}
我使用这个python脚本来接收和使用数据:
import sane
import pgmagick
import cStringIO
sane.init()
s = sane.open(sane.get_devices()[0][0])
s.mode = 'Color'
s.source = 'Transparency Unity'
s.tl_x = 15
s.tl_y = 30
s.br_x = 52
s.br_y = 55
s.x_resolution = 1600
s.y_resolution = 1600
s.depth = 16
fbuffer = cStringIO.StringIO()
s.start()
par = s.get_parameters()
print "par = ", par
st = 0
while st is 0:
st, buf = s.read()
fbuffer.write(buf)
s.cancel()
data = fbuffer.getvalue()
fbuffer.close()
px = par[2][0]
py = par[2][1]
bytesperlines = par[4]
depth = par[3]
size = "%sx%s" % (px, py)
blob = pgmagick.Blob(data)
im = pgmagick.Image()
im.density("1600x1600")
im.depth(depth)
im.size(size)
im.magick('RGB')
im.resolutionUnits(gm.ResolutionType.PixelsPerInchResolution)
im.read(blob)
im.write("img.tiff")
脚本在8位深度下运行良好,但深度设置为16位,我得到的图像颜色错误;
这是两个例子:
问题出在哪里?
编辑:我使用pgmagick,一个python包装到graphicsmagick;将graphmagick编程为量程深度设置为16位。答案 0 :(得分:0)
您可能错误地输入了字节顺序。尝试交换构成16位数据的两个字节,看看你得到了什么。