?? unit1.pas
字號:
unit Unit1;
interface
uses
Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
StdCtrls, DBCtrls, ExtCtrls, Grids, DBGridEh, ComCtrls, Db, DBTables,
Buttons, DBGrids, PrViewEh, PrnDbgeh, ToolWin, Menus, DBGridEhImpExp;
type
TForm1 = class(TForm)
DataSource2: TDataSource;
Table1: TTable;
Table2: TTable;
DataSource3: TDataSource;
PageControl1: TPageControl;
TabSheet1: TTabSheet;
DBGridEh1: TDBGridEh;
Panel1: TPanel;
TabSheet2: TTabSheet;
DBGridEh2: TDBGridEh;
TabSheet3: TTabSheet;
DBGridEh3: TDBGridEh;
DBGridEh4: TDBGridEh;
DBNavigator2: TDBNavigator;
DBNavigator3: TDBNavigator;
TabSheet4: TTabSheet;
ImageList2: TImageList;
tEmployee: TTable;
tEmployeeEmpNo: TIntegerField;
tEmployeeLastName: TStringField;
tEmployeeFirstName: TStringField;
tEmployeePhoneExt: TStringField;
tEmployeeHireDate: TDateTimeField;
tEmployeeSalary: TFloatField;
tEmployeeSalaryType: TIntegerField;
dsEmployee: TDataSource;
DBGridEh5: TDBGridEh;
qrVendors: TQuery;
qrVendorsVendorNo: TFloatField;
qrVendorsVendorName: TStringField;
qrVendorsAddress1: TStringField;
qrVendorsAddress2: TStringField;
qrVendorsCity: TStringField;
qrVendorsState: TStringField;
qrVendorsZip: TStringField;
qrVendorsCountry: TStringField;
qrVendorsPhone: TStringField;
qrVendorsFAX: TStringField;
qrVendorsPreferred: TBooleanField;
dsVendors: TDataSource;
DataSource1: TDataSource;
Query1: TQuery;
Query1VNo: TFloatField;
Query1VName: TStringField;
Query1PNo: TFloatField;
Query1PDescription: TStringField;
Query1PCost: TCurrencyField;
Query1IQty: TIntegerField;
Query1VName1: TStringField;
Query1VPreferred: TBooleanField;
TabSheet5: TTabSheet;
Panel3: TPanel;
cbClearSelection: TCheckBox;
cbShowIndicator: TCheckBox;
cbTitle: TCheckBox;
cbHighlightFocus: TCheckBox;
cbMultiselect: TCheckBox;
dsCustomer: TDataSource;
PreviewSetupPanel: TPanel;
bPrint: TButton;
bPrinterSetup: TButton;
bPrevPage: TButton;
bNextPage: TButton;
bStop: TButton;
bClosePreview: TButton;
PrintDBGridEh1: TPrintDBGridEh;
PreviewBox1: TPreviewBox;
bInpPreview: TButton;
bPreview: TButton;
bOpenClose: TButton;
bFiltr: TButton;
lPageinfo: TLabel;
cCustomPreview: TButton;
ilArrows: TImageList;
ToolBar1: TToolBar;
ToolButton1: TToolButton;
ToolButton2: TToolButton;
pmNoVisibleCols: TPopupMenu;
qCustomer: TQuery;
qCustomer2: TQuery;
dsCustomer2: TDataSource;
dbgList1: TDBGridEh;
dbgList: TDBGridEh;
cbDragNDrop: TCheckBox;
cbDichromatic: TCheckBox;
bbCopy: TBitBtn;
cbInterAppDragNDrop: TCheckBox;
ImageList1: TImageList;
PopupMenu1: TPopupMenu;
ppmCut: TMenuItem;
ppmCopy: TMenuItem;
ppmPaste: TMenuItem;
ppmDelete: TMenuItem;
ppmSelectAll: TMenuItem;
ppmPreview: TMenuItem;
procedure bFiltrClick(Sender: TObject);
procedure bOpenCloseClick(Sender: TObject);
procedure Query1UpdateRecord(DataSet: TDataSet;
UpdateKind: TUpdateKind; var UpdateAction: TUpdateAction);
procedure DBGridEh2DrawColumnCell(Sender: TObject; const Rect: TRect;
DataCol: Integer; Column: TColumnEh; State: TGridDrawState);
procedure DBGridEh2DrawFooterCell(Sender: TObject; DataCol,
Row: Integer; Column: TColumnEh; Rect: TRect; State: TGridDrawState);
procedure DBGridEh2GetCellParams(Sender: TObject; Column: TColumnEh;
AFont: TFont; var Background: TColor; State: TGridDrawState);
procedure DBGridEh2GetFooterParams(Sender: TObject; DataCol,
Row: Integer; Column: TColumnEh; AFont: TFont;
var Background: TColor; var Alignment: TAlignment;
State: TGridDrawState; var Text: String);
procedure tEmployeeCalcFields(DataSet: TDataSet);
procedure DBGridEh1TitleBtnClick(Sender: TObject; ACol: Integer;
Column: TColumnEh);
procedure cbClearSelectionClick(Sender: TObject);
procedure cbShowIndicatorClick(Sender: TObject);
procedure cbTitleClick(Sender: TObject);
procedure cbHighlightFocusClick(Sender: TObject);
procedure cbMultiselectClick(Sender: TObject);
procedure DBGridEh1SortMarkingChanged(Sender: TObject);
procedure bPrintClick(Sender: TObject);
procedure bPrinterSetupClick(Sender: TObject);
procedure bPrevPageClick(Sender: TObject);
procedure bNextPageClick(Sender: TObject);
procedure bStopClick(Sender: TObject);
procedure bClosePreviewClick(Sender: TObject);
procedure bPreviewClick(Sender: TObject);
procedure bInpPreviewClick(Sender: TObject);
procedure FormCreate(Sender: TObject);
procedure PreviewBox1PrinterPreviewChanged(Sender: TObject);
procedure cCustomPreviewClick(Sender: TObject);
procedure ToolButton2Click(Sender: TObject);
procedure ToolButton1Click(Sender: TObject);
procedure dbgListDragDrop(Sender, Source: TObject; X, Y: Integer);
procedure dbgListDragOver(Sender, Source: TObject; X, Y: Integer;
State: TDragState; var Accept: Boolean);
procedure dbgListStartDrag(Sender: TObject;
var DragObject: TDragObject);
procedure dbgList1DragDrop(Sender, Source: TObject; X, Y: Integer);
procedure dbgList1DragOver(Sender, Source: TObject; X, Y: Integer;
State: TDragState; var Accept: Boolean);
procedure qCustomerUpdateRecord(DataSet: TDataSet;
UpdateKind: TUpdateKind; var UpdateAction: TUpdateAction);
procedure qCustomer2UpdateRecord(DataSet: TDataSet;
UpdateKind: TUpdateKind; var UpdateAction: TUpdateAction);
procedure cbDragNDropClick(Sender: TObject);
procedure cbDichromaticClick(Sender: TObject);
procedure dbgListGetCellParams(Sender: TObject; Column: TColumnEh;
AFont: TFont; var Background: TColor; State: TGridDrawState);
procedure bbCopyClick(Sender: TObject);
procedure DBGridEh1KeyDown(Sender: TObject; var Key: Word;
Shift: TShiftState);
procedure cbInterAppDragNDropClick(Sender: TObject);
procedure DBGridEh2EditButtonClick(Sender: TObject);
procedure ppmCutClick(Sender: TObject);
procedure ppmCopyClick(Sender: TObject);
procedure ppmPasteClick(Sender: TObject);
procedure ppmDeleteClick(Sender: TObject);
procedure ppmSelectAllClick(Sender: TObject);
procedure ppmPreviewClick(Sender: TObject);
private
{ Private declarations }
public
procedure InplacePreviewSetupDialog(Sender: TObject);
procedure ColumnMenuItem(Sender: TObject);
function GridSelectionAsText(AGrid:TDBGridEh):String;
procedure ApplicationIdle(Sender: TObject; var Done: Boolean);
{ Public declarations }
end;
var
Form1: TForm1;
implementation
uses CustPrev, clipbrd, Unit2;
{$R *.DFM}
procedure TForm1.bFiltrClick(Sender: TObject);
begin
if (Query1.Filtered = True) then begin
Query1.Filtered := False;
bFiltr.Caption := 'Filtr';
end else begin
Query1.Filtered := True;
bFiltr.Caption := 'UnFiltr';
end;
end;
procedure TForm1.bOpenCloseClick(Sender: TObject);
begin
if (Query1.Active = False) then begin
Query1.Active := True;
bOpenClose.Caption := 'Close';
end else begin
Query1.Active := False;
bOpenClose.Caption := 'Open';
end;
end;
procedure TForm1.Query1UpdateRecord(DataSet: TDataSet;
UpdateKind: TUpdateKind; var UpdateAction: TUpdateAction);
begin
//
end;
procedure TForm1.DBGridEh2DrawColumnCell(Sender: TObject;
const Rect: TRect; DataCol: Integer; Column: TColumnEh;
State: TGridDrawState);
begin
if (Rect.Top = DBGridEh2.CellRect(DBGridEh2.Col,DBGridEh2.Row).Top) and (not (gdFocused in State) or not DBGridEh2.Focused) then
DBGridEh2.Canvas.Brush.Color := clAqua;
DBGridEh2.DefaultDrawColumnCell(Rect,DataCol,Column,State);
end;
procedure TForm1.DBGridEh2DrawFooterCell(Sender: TObject; DataCol,
Row: Integer; Column: TColumnEh; Rect: TRect; State: TGridDrawState);
begin
DBGridEh2.DefaultDrawFooterCell(Rect,DataCol,Row,Column,State);
end;
procedure TForm1.DBGridEh2GetCellParams(Sender: TObject; Column: TColumnEh;
AFont: TFont; var Background: TColor; State: TGridDrawState);
begin
if Query1.FieldByName('IQty').Text = '17' then
AFont.Style := AFont.Style + [fsBold];
end;
procedure TForm1.DBGridEh2GetFooterParams(Sender: TObject; DataCol,
Row: Integer; Column: TColumnEh; AFont: TFont; var Background: TColor;
var Alignment: TAlignment; State: TGridDrawState; var Text: String);
begin
if (Column.Field.FieldName = 'PDescription') then Text := 'Qty = ' + Text
else if (Column.Field.FieldName = 'VName') then Text := Text + ' records';
end;
procedure TForm1.tEmployeeCalcFields(DataSet: TDataSet);
begin
if (tEmployeeSalary.AsFloat < 15000) then
tEmployeeSalaryType.AsFloat := 5
else if (tEmployeeSalary.AsFloat < 20000) then
tEmployeeSalaryType.AsFloat := 4
else if (tEmployeeSalary.AsFloat < 25000) then
tEmployeeSalaryType.AsFloat := 3
else if (tEmployeeSalary.AsFloat < 30000) then
tEmployeeSalaryType.AsFloat := 2
else if (tEmployeeSalary.AsFloat < 50000) then
tEmployeeSalaryType.AsFloat := 1
else
tEmployeeSalaryType.AsFloat := 0;
end;
procedure TForm1.DBGridEh1TitleBtnClick(Sender: TObject; ACol: Integer;
Column: TColumnEh);
begin
{ case Column.Title.SortMarker of
smNoneEh: Column.Title.SortMarker := smDownEh;
smDownEh: Column.Title.SortMarker := smUpEh;
smUpEh: Column.Title.SortMarker := smNoneEh;
end;}
end;
procedure TForm1.cbClearSelectionClick(Sender: TObject);
begin
if cbClearSelection.Checked then
dbgList.OptionsEh := dbgList.OptionsEh + [dghClearSelection]
else
dbgList.OptionsEh := dbgList.OptionsEh - [dghClearSelection];
end;
procedure TForm1.cbShowIndicatorClick(Sender: TObject);
begin
if cbShowIndicator.Checked then
dbgList.Options := dbgList.Options + [dgIndicator]
else
dbgList.Options := dbgList.Options - [dgIndicator];
end;
procedure TForm1.cbTitleClick(Sender: TObject);
begin
if cbTitle.Checked then
dbgList.Options := dbgList.Options + [dgTitles]
else
dbgList.Options := dbgList.Options - [dgTitles];
end;
procedure TForm1.cbHighlightFocusClick(Sender: TObject);
begin
if cbHighlightFocus.Checked then
dbgList.OptionsEh := dbgList.OptionsEh + [dghHighlightFocus]
else
dbgList.OptionsEh := dbgList.OptionsEh - [dghHighlightFocus];
end;
procedure TForm1.cbMultiselectClick(Sender: TObject);
begin
if cbMultiselect.Checked then
dbgList.Options := dbgList.Options + [dgMultiselect]
else
dbgList.Options := dbgList.Options - [dgMultiselect];
end;
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -