检测打印机纸张的状态

时间:2011-09-28 14:46:51

标签: delphi printing

我需要从打印机获取纸张状态信息。我有一个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; 

问题是不同的cmds我总是得到相同的字符串.... 你能给我一个转义函数的例子,最后一个参数不是nill吗? 获得纸质状态的替代方案?

1 个答案:

答案 0 :(得分:3)

我想您正在使用上面的Delphi 2009并且您使用this source作为示例,因此您的问题可能是由Unicode参数引起的。在2009年版本的Delphi中,string类型定义为UnicodeString,而在下面的Delphi 2009中定义为AnsiString,同样代表Char的{​​{1}}类型WideChar Delphi 2009 up和AnsiChar以下。

如果是这样,那么我认为你的缓冲区数据长度至少有问题,因为Char = WideChar需要2个字节而你使用的是StrLen函数,它返回的字符数不能对应数据大小为number of chars * 2 bytes

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

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;