检测打印机纸张状态

3
我需要从打印机中获取纸张状态信息。我有一系列ESC/POS命令的列表。 我正在尝试使用转义函数发送这些命令。 http://msdn.microsoft.com/en-us/library/windows/desktop/dd162701%28v=vs.85%29.aspx 以下是我的代码:
type
TPrnBuffRec = record
  bufflength: Word;
  Buff_1: array[0..255] of Char;
end;

procedure TFTestStampa.SpeedButton2Click(Sender: TObject);
var
  Buff: TPrnBuffRec;
  BuffOut: TPrnBuffRec;
  TestInt: Integer;
  cmd : string;
begin
  printer.BeginDoc;

  try
    TestInt := PassThrough;
    if Escape(Printer.Handle, QUERYESCSUPPORT, SizeOf(TESTINT),
@testint, nil) > 0 then
      begin
        cmd := chr(10) + chr(04) + '4';
        StrPCopy(Buff.Buff_1, cmd);
        Buff.bufflength := StrLen(Buff.Buff_1);
        Escape(Printer.Canvas.Handle, Passthrough, 0, @buff,
@buffOut);

        ShowMessage( conver(strPas(buffOut.Buff_1)) );
      end

  finally
    printer.EndDoc;

end;


function TFTestStampa.Conver(s: string): String;
var
  i:  Byte;
  t : String;
begin
  t := '';
  for i := 1 to Length(s)  do
    t := t + IntToHex(Ord(s[i]), 2) + ' ';
  Result := t;
end; 

问题在于我得到的不同命令始终是相同的字符串.... 你能给我一个使用最后一个参数非空的转义函数的例子吗? 获得纸张状态的替代方法?


我是否正确地读取了 buffout? - user817057
1个回答

3

我猜测您正在使用Delphi 2009以上版本,并且使用了这个源代码作为您的示例,因此您的问题可能是由Unicode参数引起的。自Delphi 2009以来,string类型被定义为UnicodeString,而在Delphi 2009以下版本中为AnsiString,同样的情况也适用于Char,在Delphi 2009及以上版本中为WideChar,而在以下版本中为AnsiChar

如果是这样的话,那么我认为您至少在缓冲区数据长度方面存在问题,因为Char = WideChar需要2个字节,而您使用了StrLen函数返回的字符数不能对应于字符数 * 2字节的数据大小。

我希望这能解决您的问题,但我无法验证,因为我没有您的打印机 :)

type
  TPrinterData = record
    DataLength: Word;
    Data: array [0..255] of AnsiChar; // let's use 1 byte long AnsiChar
end;

function Convert(const S: AnsiString): string;
var
  I: Integer; // 32-bit integer is more efficient than 8-bit byte type
  T: string;  // here we keep the native string data type
begin
  T := '';
  for I := 1 to Length(S) do
    T := T + IntToHex(Ord(S[I]), 2) + ' ';
  Result := T;
end;

procedure TFTestStampa.SpeedButton2Click(Sender: TObject);
var
  TestInt: Integer;
  Command: AnsiString;
  BufferIn: TPrinterData;
  BufferOut: TPrinterData;
begin
  Printer.BeginDoc;

  try
    TestInt := PASSTHROUGH;

    if Escape(Printer.Handle, QUERYESCSUPPORT, SizeOf(TestInt), @TestInt, nil) > 0 then
    begin
      Command := Chr(10) + Chr(04) + '4';
      StrPCopy(BufferIn.Data, Command);
      BufferIn.DataLength := StrLen(Command);
      FillChar(BufferOut.Data, Length(BufferOut.Data), #0);
      BufferOut.DataLength := 0;
      Escape(Printer.Canvas.Handle, PASSTHROUGH, 0, @BufferIn, @BufferOut);

      ShowMessage(Convert(StrPas(BufferOut.Data)));
    end

  finally
    Printer.EndDoc;
  end;
end;

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接