Detecção automática da unidade Duplex para GPD
Suponha que o arquivo GPD tenha um recurso Duplex definido como o exemplo a seguir, de modo que a unidade duplex seja instalável:
*Feature: Duplex
{
*rcNameID: =TWO_SIDED_PRINTING_DISPLAY
*DefaultOption: NONE
*Option: NONE
{
*rcNameID: =NONE_DISPLAY
*Command: CmdSelect
{
*Order: DOC_SETUP.9
*Cmd: "<1B>&l0S"
}
}
*Option: VERTICAL
{
*rcNameID: =FLIP_ON_LONG_EDGE_DISPLAY
*Command: CmdSelect
{
*Order: DOC_SETUP.10
*Cmd: "<1B>&l1S"
}
}
*Option: HORIZONTAL
{
*rcNameID: =FLIP_ON_SHORT_EDGE_DISPLAY
*Command: CmdSelect
{
*Order: DOC_SETUP.10
*Cmd: "<1B>&l2S"
}
}
}
*%
*% Installable Option
*%
*Feature: DuplexUnit
{
*rcNameID: 429 *% Duplex Unit
*HelpIndex: 12004
*FeatureType: PRINTER_PROPERTY
*DefaultOption: FALSE
*Option: NotInstalled
{
*rcNameID: 444
*DisabledFeatures: LIST(Duplex.VERTICAL, Duplex.HORIZONTAL)
}
*Option: Installed
{
*rcNameID: 443
}
}
O exemplo de código GDL a seguir fornece a capacidade de fazer a detecção automática da existência de uma unidade duplex (que é descrita no exemplo de código GPD anterior) e definir a opção apropriada. Neste exemplo, o spooler envia a consulta mostrada no constructo *BidiQuery . Quando a impressora recebe a consulta, ela responde com um dos dois valores de construção de opção possíveis.
*Feature: DuplexUnit
{
*% Note that the *BidiQuery and *BidiResponse constructs must have the same names
*BidiQuery: DuplexUnit
{
*QueryString: "\Printer.Configuration.DuplexUnit:Installed"
}
*BidiResponse: DuplexUnit
{
*ResponseType: BIDI_BOOL
*ResponseData: ENUM_OPTION(DuplexUnit)
}
*Option: NotInstalled
{
*BidiValue: BOOL(FALSE)
}
*Option: Installed
{
*BidiValue: BOOL(TRUE)
}
}