我在Microsoft Dynamics中有一個用於打印自定義標籤的報告。運行報告並傳遞要打印的頁數和一些值
報表本身有一個來自Items表的DataItem。如果您運行報告,您可以鍵入項目編號並在選定的熱敏打印機上打印標籤。現在
,我要歸檔的是,如果我有一個採購訂單,我想克利克somwhere和Navision公司應該做這樣的事情:
運行報告「50070」與項目「10001」 6份標籤; 運行項目'10020'的報告'50070'3份標籤;
等等。
我沒有發現這個話題。我試圖用一些副本中提到的副本循環來做到這一點,但這並不像我想要的那樣工作。
概述
報告DataItems:
「項目」 - >記錄::項目
下面的代碼是從項目 - OnAfterGetRecord() - 觸發
RecordNo := RecordNo + 1;
ColumnNo := ColumnNo + 1;
ItData[ColumnNo][1] := FORMAT("No.");
ItData[ColumnNo][2] := FORMAT(Description);
ItData[ColumnNo][3] := FORMAT(Var1);
ItData[ColumnNo][4] := FORMAT(Var2);
ItData[ColumnNo][5] := FORMAT("Unit Price");
ItData[ColumnNo][5] := FORMAT("Unit Price" * 1.19);
// finding own barcode first, if no own barcode found, take
// the one you can get
barcodeStr := '';
recBarcode.SETFILTER("Item No.", "No.");
recBarcode.SETFILTER("Barcode No.", '99916*');
IF recBarcode.FINDFIRST THEN BEGIN
barcodeStr := recBarcode."Barcode No.";
END ELSE BEGIN
recBarcode.RESET;
recBarcode.SETRANGE("Item No.", "No.");
IF recBarcode.FINDFIRST THEN BEGIN
barcodeStr := recBarcode."Barcode No.";
END;
END;
// ask user, if to printing barcode is not a company own
// barcode, and let him decide if he whishes to print anyway
IF STRLEN(barcodeStr) = 13 THEN BEGIN
IF (COPYSTR(barcodeStr, 1, 5) <> '99916') THEN BEGIN
IF NOT CONFIRM('This item has NO company own barcode. Do you whish to print it anyway?', FALSE) THEN
EXIT;
END;
// format the barcode-string to a format, that the barcode font
// can understand and printing it properly for reading with a scanner
EAN13 := DADA.GetPrintTextEAN13(barcodeStr);
END;
COMPRESSARRAY(ItData[ColumnNo]);
IF RecordNo = NoOfRecords THEN BEGIN
FOR i := ColumnNo + 1 TO NoOfColumns DO
CLEAR(Addr[i]);
ColumnNo := 0;
END ELSE BEGIN
IF ColumnNo = NoOfColumns THEN
ColumnNo := 0;
END;
// finding a suiting logo for the barcode, user can choose between none, dd or ex
IF intLogoOption = 2 THEN BEGIN
IF EXISTS ('N:\Labelprinting\dd\75x75\sw_for75x75.bmp') THEN
TT.BLOBImport(BLOBRef, 'N:\Labelprinting\dd\75x75\sw_for75x75.bmp', FALSE);
END ELSE IF intLogoOption = 3 THEN BEGIN
IF EXISTS ('N:\Labelprinting\ex\75x75\sw_for75x75.png') THEN
TT.BLOBImport(BLOBRef, 'N:\Labelprinting\ex\75x75\sw_for75x75.png', FALSE);
END;
CALCFIELDS(Item.Picture);
我的目標是,用戶可以點擊一次並選擇一次打印機,並且所有標籤都可以正確打印。