Приложение. Исходный код системы (по модулям).
WriteString('GRID_CONFIG','MARK3',IntToStr(DBGrid1.Columns[3].Width));
WriteString('GRID_CONFIG','MARK4',IntToStr(DBGrid1.Columns[4].Width));
WriteString('GRID_CONFIG','MARK5',IntToStr(DBGrid1.Columns[5].Width));
WriteString('GRID_CONFIG','MARK6',IntToStr(DBGrid1.Columns[6].Width));
WriteString('GRID_CONFIG','SUMMARK',IntToStr(DBGrid1.Columns[7].Width));
WriteString('GRID_CONFIG','SCHOOL',IntToStr(DBGrid1.Columns[8].Width));
UpdateFile;
end;
Config.Free;
Application.MessageBox('Настройки успешно сохранены!','Сообщение',mb_Ok+mb_IconAsterisk);
end;
except
Application.MessageBox('Ошибка сохранения настроек!','Ошибка',mb_Ok+mb_IconHand);
Exit;
end;
end;
procedure TForm1.BitBtn3Click(Sender: TObject);
begin
Form5.ShowModal;
end;
procedure TForm1.N3Click(Sender: TObject);
var
i:integer;
begin
OpenDialog1.InitialDir:=GetCurrentDir+'\Bases';
if OpenDialog1.Execute then
begin
try
with Table1 do
begin
Active := False;
DatabaseName := 'Olymp';
TableType := ttParadox;
TableName := ExtractFileName(OpenDialog1.FileName);
Active:=True;
end;
dsOlymp.DataSet:=Table1;
DBGrid1.DataSource:=dsOlymp;
Application.MessageBox('База успешно открыта.','Сообщение',mb_Ok+MB_ICONASTERISK);
except
Application.MessageBox('Ошибка открытия базы. Возможно она не существует.','Ошибка',mb_Ok+MB_ICONHAND);
Exit;
end;
end;
end;
procedure TForm1.BitBtn4Click(Sender: TObject);
begin
Form7.ShowModal;
end;
end.
Модуль 2.
Код этого модуля отвечает за формирование баз данных, то есть за запись участника.
unit Unit2;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, ExtCtrls, StdCtrls, Buttons;
type
TForm2 = class(TForm)
Panel1: TPanel;
GroupBox1: TGroupBox;
BitBtn1: TBitBtn;
BitBtn2: TBitBtn;
Edit1: TEdit;
Edit2: TEdit;
Label1: TLabel;
Label2: TLabel;
Edit3: TEdit;
Edit4: TEdit;
Edit5: TEdit;
Edit6: TEdit;
Edit7: TEdit;
Edit8: TEdit;
Label3: TLabel;
Label4: TLabel;
Label5: TLabel;
Label6: TLabel;
Label7: TLabel;
Label8: TLabel;
Label9: TLabel;
procedure BitBtn1Click(Sender: TObject);
procedure BitBtn2Click(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
end;
var
Form2: TForm2;
implementation
uses Unit1, DB, DBTables;
{$R *.dfm}
procedure TForm2.BitBtn1Click(Sender: TObject);
begin
ModalResult:=mrCancel;
end;
procedure TForm2.BitBtn2Click(Sender: TObject);
var
Fio,Sch:string;
n1,n2,n3,n4,n5,n6,snum:double;
begin
Fio:=Edit1.Text;
Sch:=Edit2.Text;
if (Fio='') or (Sch='') then
begin
Application.MessageBox('Не введено ФИО или Школа!','Ошибка',mb_Ok+mb_IconHand);
Edit1.SetFocus;
Exit;
end;
try
n1:=StrToFloat(Edit3.Text);
n2:=StrToFloat(Edit4.Text);
n3:=StrToFloat(Edit5.Text);
n4:=StrToFloat(Edit6.Text);
n5:=StrToFloat(Edit7.Text);
n6:=StrToFloat(Edit8.Text);
except
Application.MessageBox('Одно или несколько текстовых полей заполнены неверно!','Ошибка',mb_Ok+mb_IconHand);
Edit1.SetFocus;
Exit;
end;
snum:=n1+n2+n3+n4+n5+n6;
try
with Form1.Table1 do
begin
Active:=True;
Append;
FieldValues['COUNTER']:=RecordCount+1;;
FieldValues['FIO']:=Fio;
FieldValues['MARK1']:=n1;
FieldValues['MARK2']:=n2;
FieldValues['MARK3']:=n3;
FieldValues['MARK4']:=n4;
FieldValues['MARK5']:=n5;
FieldValues['MARK6']:=n6;
FieldValues['SUMMARK']:=snum;
FieldValues['SCHOOL']:=Sch;
Post;
end;
Edit1.Text:='';