2011-09-28 187 views
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; 

问题是不同的CMDS我总是得到相同的字符串.... 你能给我一个最后一个参数不是nill的逃生函数的例子? 获取纸张状态的替代方法?

+0

难道我读正确buffout? – user817057

回答

3

我想你正在使用上面的Delphi 2009,并且你使用this source作为例子,所以你的问题可能是由Unicode参数引起的。在德尔福自2009版以来,string类型被定义为UnicodeString,而在德尔福2009年下面作为AnsiStringChar也是,在德尔福2009年和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;