📄 cash.pas
字号:
unit cash;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, ExtCtrls, Menus, ComCtrls, ToolWin, Buttons, StdCtrls, AppEvnts,
LabelButton, TradeImage, MaskImageButton, MoveImageButton, DB, Grids,
DBGrids, DBTables;
type
Tfrm_cash = class(TForm)
palUp: TPanel;
palLeftUp: TPanel;
imgLeftUp: TImage;
palRightUp: TPanel;
imgRightUp: TImage;
palUpMid: TPanel;
imgCaption: TImage;
palDown: TPanel;
imgLeftDown: TImage;
imgRightDown: TImage;
imgDownMin: TImage;
palLeft: TPanel;
palRight: TPanel;
imgRight: TImage;
imgCloseButton: TImage;
imgMinButton: TImage;
imgSizeButton: TImage;
imgMaxButton: TImage;
imgRestoreButton: TImage;
imgSysIcon: TImage;
popSystemMenu: TPopupMenu;
N_Restore: TMenuItem;
N_Max: TMenuItem;
N_Min: TMenuItem;
N_Move: TMenuItem;
N_Size: TMenuItem;
N_Speater: TMenuItem;
N_Close: TMenuItem;
palClient: TPanel;
lbCaption: TLabel;
CoolBarMenu: TCoolBar;
ToolBarMenu: TToolBar;
imgLeft: TImage;
imgColorLeftUp: TImage;
imgGrayCaption: TImage;
imgGrayMenuBar: TImage;
imgGrayRightUp: TImage;
imgColorCaption: TImage;
imgGrayLeftUp: TImage;
imgColorRightUp: TImage;
imgRightUp1: TImage;
imgLeftUp1: TImage;
imgColorMenubar: TImage;
Panel1: TPanel;
DBGrid1: TDBGrid;
DataSource1: TDataSource;
GroupBox1: TGroupBox;
date1: TDateTimePicker;
date2: TDateTimePicker;
e_hzmx: TComboBox;
Label1: TLabel;
Label2: TLabel;
b_cx: TMoveImgBtn;
b_prn: TMoveImgBtn;
bLabel_cx: TLabelBtn;
bLabel_prn: TLabelBtn;
Bevel1: TBevel;
e_hjsr: TEdit;
Label3: TLabel;
Label4: TLabel;
e_hjzc: TEdit;
Label5: TLabel;
e_hjye: TEdit;
procedure imgMinButtonClick(Sender: TObject);
procedure imgSizeButtonClick(Sender: TObject);
procedure imgCloseButtonClick(Sender: TObject);
procedure imgCaptionMouseDown(Sender: TObject; Button: TMouseButton;
Shift: TShiftState; X, Y: Integer);
procedure imgCaptionMouseMove(Sender: TObject; Shift: TShiftState; X,
Y: Integer);
procedure imgCaptionMouseUp(Sender: TObject; Button: TMouseButton;
Shift: TShiftState; X, Y: Integer);
procedure FormCreate(Sender: TObject);
procedure imgSysIconMouseDown(Sender: TObject; Button: TMouseButton;
Shift: TShiftState; X, Y: Integer);
procedure popSystemMenuPopup(Sender: TObject);
procedure N_SizeClick(Sender: TObject);
procedure N_MoveClick(Sender: TObject);
procedure FormShow(Sender: TObject);
procedure b_cxClick(Sender: TObject);
procedure FormClose(Sender: TObject; var Action: TCloseAction);
procedure b_prnClick(Sender: TObject);
private
{ Private declarations }
canmove:boolean;
curPoint:TPoint;
oldPoint:TPoint;
Canvas:TCanvas;
protected
procedure CreateParams(var Params:TCreateParams);override;
procedure WMActivate(var Msg:TWMACTIVATE); message WM_ACTIVATE;
public
{ Public declarations }
end;
var
frm_cash: Tfrm_cash;
sr,zc,ye: Variant;
implementation
uses datam, qrcash;
{$R *.dfm}
procedure Tfrm_cash.CreateParams(var Params:TCreateParams);
begin
inherited CreateParams(Params);
if BorderStyle<>bsNone then
Params.Style :=WS_THICKFRAME or WS_POPUP or WS_BORDER;
end;
procedure Tfrm_cash.imgMinButtonClick(Sender: TObject);
begin
if Application.MainForm =self then
Application.Minimize
else
DefWindowProc(Handle, WM_SYSCOMMAND, SC_MINIMIZE, 0);
end;
procedure Tfrm_cash.imgSizeButtonClick(Sender: TObject);
begin
if self.WindowState = wsNormal then
begin
DefWindowProc(Handle, WM_SYSCOMMAND, SC_MAXIMIZE, 0);
imgSizeButton.Picture :=imgRestoreButton.Picture;
end
else
begin
DefWindowProc(Handle, WM_SYSCOMMAND, SC_RESTORE, 0);
imgSizeButton.Picture :=imgMaxButton.Picture;
end;
end;
procedure Tfrm_cash.imgCloseButtonClick(Sender: TObject);
begin
DefWindowProc(Handle, WM_SYSCOMMAND, SC_CLOSE, 0);
end;
procedure Tfrm_cash.imgCaptionMouseDown(Sender: TObject;
Button: TMouseButton; Shift: TShiftState; X, Y: Integer);
begin
if (Button=mbLeft)and(ssLeft in Shift)then
begin
canmove:=true;
Canvas:=TCanvas.Create;
with Canvas do
begin
pen.Style :=psdot;
brush.Style :=bsClear;
pen.Width :=2;
Pen.Mode :=pmNotXor;
Handle :=GetDC(0);
Rectangle(left,top,Left+width,top+height);
curPoint.X :=X;
curPoint.Y :=Y;
oldPoint.X :=Left;
oldPoint.Y :=Top;
end; //end with
end; //end if
end;
procedure Tfrm_cash.imgCaptionMouseMove(Sender: TObject;
Shift: TShiftState; X, Y: Integer);
begin
if not canmove then exit;
with Canvas do
begin
Rectangle(oldPoint.x,oldPoint.y,oldPoint.x+Width,oldPoint.y+Height);
oldPoint.x :=Left +X-curPoint.x;
oldPoint.y :=Top +Y-curPoint.y;
Rectangle(oldPoint.x,oldPoint.y,oldPoint.x+Width,oldPoint.y+Height);
end;
end;
procedure Tfrm_cash.imgCaptionMouseUp(Sender: TObject;
Button: TMouseButton; Shift: TShiftState; X, Y: Integer);
begin
if not canmove then exit;
with Canvas do
begin
Rectangle(oldPoint.x,oldPoint.y,oldPoint.x+Width,oldPoint.y+Height);
Left :=oldPoint.x;
Top :=oldPoint.y;
Free;
end;
canmove:=not canmove;
end;
procedure Tfrm_cash.FormCreate(Sender: TObject);
begin
lbCaption.Caption :=Caption;
end;
procedure Tfrm_cash.imgSysIconMouseDown(Sender: TObject;
Button: TMouseButton; Shift: TShiftState; X, Y: Integer);
begin
PopSystemMenu.Popup(Left+ImgSysIcon.Left,Top+ImgSysIcon.Top+ImgSysIcon.Height);
end;
procedure Tfrm_cash.popSystemMenuPopup(Sender: TObject);
begin
N_Restore.Enabled :=imgSizeButton.Visible and (WindowState =wsMaximized);
N_Max.Enabled :=imgSizeButton.Visible and (WindowState =wsNormal);
N_Size.Enabled :=imgSizeButton.Visible ;
n_min.Enabled:=imgMinButton.Visible;
end;
procedure Tfrm_cash.N_SizeClick(Sender: TObject);
begin
DefWindowProc(Handle, WM_SYSCOMMAND, SC_SIZE, 0);
end;
procedure Tfrm_cash.N_MoveClick(Sender: TObject);
begin
DefWindowProc(Handle, WM_SYSCOMMAND, SC_MOVE, 0);
end;
procedure Tfrm_cash.FormShow(Sender: TObject);
begin
if WindowState=wsNormal then
imgSizeButton.Picture.Bitmap :=imgMaxButton.Picture.Bitmap
else if WindowState=wsMaximized then
imgSizeButton.Picture.Bitmap :=imgRestoreButton.Picture.Bitmap;
dm.ADOQ_cx.Close;
dm.adoq_cx.SQL.Clear;
dm.ADOQ_cx.SQL.Add('select 日期,sum(收入) as 收入,sum(支出) as 支出,sum(收入)-sum(支出) as 余额 from cashbook where 日期>=:rq1 and 日期<=:rq2 group by 日期');
dm.ADOQ_cx.Parameters[0].value:=datetostr(date());
dm.ADOQ_cx.Parameters[1].Value:=datetostr(date());
dm.ADOQ_cx.Open;
date1.Date:=date();
date2.Date:=date();
sr:=0;
zc:=0;
ye:=0;
dm.ADOQ_cx.First;
while not dm.ADOQ_cx.Eof do
begin
sr:=sr+dm.adoq_cx.fieldbyname('收入').asvariant;
zc:=zc+dm.adoq_cx.fieldbyname('支出').asvariant;
dm.ADOQ_cx.next;
end;
e_hjsr.Text:=formatfloat('0.00',sr);
e_hjzc.Text:=formatfloat('0.00',zc);
e_hjye.Text:=formatfloat('0.00',sr-zc);
end;
procedure Tfrm_cash.WMActivate(var Msg: TWMACTIVATE);
begin
if (Msg.Active =WA_ACTIVE) or (Msg.Active =WA_CLICKACTIVE) then
begin
imgCaption.Picture.Bitmap :=imgColorCaption.Picture.Bitmap;
imgLeftUp1.Picture.Bitmap :=imgColorLeftUp.Picture.Bitmap;
imgRightUp1.Picture.Bitmap :=imgColorRightUp.Picture.Bitmap;
coolBarMenu.Bitmap :=imgColorMenubar.Picture.Bitmap;
end
else begin
imgCaption.Picture.Bitmap :=imgGrayCaption.Picture.Bitmap;
imgLeftUp1.Picture.Bitmap :=imgGrayLeftUp.Picture.Bitmap;
imgRightUp1.Picture.Bitmap :=imgGrayRightUp.Picture.Bitmap;
coolBarMenu.Bitmap :=imgGrayMenubar.Picture.Bitmap;
end;
end;
procedure Tfrm_cash.b_cxClick(Sender: TObject);
begin
if date1.Date>date2.Date then
begin
application.MessageBox(pchar('起始日期不能大于终止日期!')
,pchar('提示'),48);
date1.SetFocus();
exit;
end;
if e_hzmx.Text='汇总' then
begin
dm.ADOQ_cx.Close;
dm.adoq_cx.SQL.Clear;
dm.ADOQ_cx.SQL.Add('select 日期,sum(收入) as 收入,sum(支出) as 支出,sum(收入)-sum(支出) as 余额 from cashbook where 日期>=:rq1 and 日期<=:rq2 group by 日期');
dm.ADOQ_cx.Parameters[0].value:=datetostr(date1.DATE);
dm.ADOQ_cx.Parameters[1].Value:=datetostr(date2.DATE);
dm.ADOQ_cx.Open;
end
else
begin
dm.ADOQ_cx.Close;
dm.adoq_cx.SQL.Clear;
dm.ADOQ_cx.SQL.Add('select 日期,摘要,sum(收入) as 收入,sum(支出) as 支出,sum(收入)-sum(支出) as 余额 from cashbook where 日期>=:rq1 and 日期<=:rq2 group by 日期,摘要');
dm.ADOQ_cx.Parameters[0].value:=datetostr(date1.DATE);
dm.ADOQ_cx.Parameters[1].Value:=datetostr(date2.DATE);
dm.ADOQ_cx.Open;
end;
sr:=0;
zc:=0;
ye:=0;
dm.ADOQ_cx.First;
while not dm.ADOQ_cx.Eof do
begin
sr:=sr+dm.adoq_cx.fieldbyname('收入').asvariant;
zc:=zc+dm.adoq_cx.fieldbyname('支出').asvariant;
dm.ADOQ_cx.next;
end;
e_hjsr.Text:=formatfloat('0.00',sr);
e_hjzc.Text:=formatfloat('0.00',zc);
e_hjye.Text:=formatfloat('0.00',sr-zc);
end;
procedure Tfrm_cash.FormClose(Sender: TObject; var Action: TCloseAction);
begin
dm.ADOQ_cx.Close;
dm.adoq_cx.SQL.Clear;
release;
end;
procedure Tfrm_cash.b_prnClick(Sender: TObject);
begin
if qr_cash=nil then
qr_cash:=Tqr_cash.Create(Application);
with qr_cash do
begin
qr_cash.QRLabelrq.Caption:='日期:'+datetostr(date1.date)+' ---- '+datetostr(date2.date);
qr_cash.Preview;
end;
end;
end.
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -