Цветная графика растра PCL искажена.Код включен:что я упускаю из виду?
-
08-07-2019 - |
Вопрос
Приведенная ниже функция печатает цветное растровое изображение на принтере PCL-5.Функция была адаптирована из имеющейся у нас функции двухцветной печати (1 бит / с), которая работала идеально, за исключением зернистой двухцветной печати.Проблема в том, что изображение отображается с большой черной полосой, простирающейся от правой части изображения до края страницы, вот так:
IMAGE#########################################
IMAGE#########AREA COMPLETELY BLACK###########
IMAGE#########################################
В остальном само изображение выглядит идеально.
Различные инструменты преобразования PCL в PDF вообще не отображают изображение, что наводит меня на мысль, что я забыл что-то сделать.Соответствующие сбросы (\u001bE\u001b%-12345X) были отправлены до, а страницы-после.
Есть там какие-нибудь эксперты по PCL?У меня есть Техническое справочное руководство PCL 5 Color, и оно помогло мне зайти так далеко.Хотя это последнее сводит меня с ума.
*Редактировать:Теперь я знаю, какая команда вызывает проблему, но я не знаю почему:
stream("\u001b*r0F");
Это должно поддерживать поворот изображения вместе со страницей (книжный, альбомный).Если я удалю это, проблема исчезнет.Я могу компенсировать это, предварительно повернув растровое изображение, но я действительно хочу знать, что вызвало это!
static void PrintImage()
{
// Get an image into memory
Image original = Image.FromFile("c:\\temp\\test.jpg");
Bitmap newBitmap = new Bitmap(original, original.Width, original.Height);
stream(String.Format("\u001b*p{0:d}x*p{1:d}Y", 1000, 1000));// Set cursor.
stream("\u001b*t300R"); // 300 DPI
stream(String.Format("\u001b*r{0:d}T", original.Height)); // Height
stream(String.Format("\u001b*r{0:d}S", original.Width)); // Width
stream("\u001b*r3U"); // 8-bit color palette
stream("\u001b*r0F"); // Follow logical page layout (landscape, portrait, etc..)
// Set palette depth, 3 bytes per pixel RGB
stream("\u001b*v6W\u0000\u0003\u0000\u0008\u0008\u0008");
stream("\u001b*r1A"); // Start raster graphics
stream("\u001b*b0M"); // Compression 0 = None, 1 = Run Length Encoding
// Not fast, but fast enough.
List<byte> colors = new List<byte>();
for (int y2 = 0; y2 < original.Height; y2++)
{
colors.Clear();
for (int x2 = 0; x2 < original.Width; x2++)
{
Color c = newBitmap.GetPixel(x2, y2);
colors.Add(c.R);
colors.Add(c.G);
colors.Add(c.B);
}
stream(String.Format("\u001b*b{0}W", colors.Count)); // Length of data to send
streamBytes(colors.ToArray()); // Binary data
}
stream("\u001b*rB"); // End raster graphics (also tried *rC -- no effect)
}
Решение
Есть несколько проблем с вашим кодом.Во-первых, ваш код положения курсора неверен, он должен гласить:
"\u001b*p{0:d}x1:d}Y", 1000, 1000
Это приравнивается к:
<esc>*p1000x1000Y
у тебя было:
<esc>*p1000x*p1000Y
При объединении команд PCL вместе вы сопоставляете одно и то же параметризованное значение и группу, а затем просто добавляете значение + параметризованный символ + значение + параметризованный символ и т.д.Убедитесь, что последний параметризованный символ является заглавной буквой, которая обозначает окончание команды PCL.
Также при определении изображения я рекомендую вам также указать ширину и высоту в десятичных точках, это должно помочь с масштабированием изображения (* r3A) на странице, поэтому добавьте это (сразу после вашей команды разрешения должно быть подходящее место для этого):
Int32 deciHeight = original.Height / (int)original.HorizontalResolution * 720;
Int32 deciWidth = original.Width / (int)original.VerticalResolution * 720;
stream("\u001b*t{0:d}h{1:d}V", deciHeight, deciWidth));
Другая рекомендация - записать все это в файл (следите за своими кодировками) и использовать один из немногих средств просмотра PCL для просмотра ваших данных по сравнениювсегда печатаю это.Это сэкономит вам немного времени и пару лесов!Я перепробовал их все и буду рекомендовать потратить 89 долларов и приобрести pclWorks ( ПКЛ ) - работы.У них также есть полный SDK, если вы собираетесь использовать много PCL.Мы не используем это, поскольку сами жестко кодируем все PCL, но выглядит это неплохо.
Что касается поворота, у нас возникли проблемы на каком-то устройстве, вы могли бы сначала просто повернуть jpg (original.RotateFlip), а затем записать его.
Сегодня у меня не так много времени, но надеюсь, что мои комментарии помогут.Я могу протестировать ваш код в понедельник или вторник, поработать с ним и оставить любые дальнейшие комментарии.
Имейте в виду, что, хотя PCL является стандартом, его поддержка от производителя к производителю и от устройства к устройству может быть проблемой и сильно отличаться.При выполнении основных действий большинство устройств кажутся нормальными;однако, если вы займетесь макросами или сложной графикой, вы обнаружите разницу.