procedure TfrmSetEllipsoid.FormDestroy(Sender: TObject);
begin
FTrans.Free;
FSql.Free;
FDatasource.Free;
//Make sure TSQLite3Connection is the last.
FDBCon.Free;
end;
ลบ Record
การเลื่อน Record ทำได้โดยการลิกที่ปุ่มลูกศร ซ้ายและขวา
เมื่อคลิกปุ่ม “New…” ทำการป้อนรูปทรงรีใหม่เข้าไป หรือแก้ไขค่าทรงรีเดิม ฐานข้อมูลจะไม่มีการเปลี่ยนแปลงจนกระทั่ง ผู้ใช้โปรแกรมคลิกที่ปุ่ม “Apply” โปรแกรมจะทำตรวจสอบว่าผู้ใช้เพิ่ม record จากตัวแปร FNewRecordState ถ้าเป็นการ Update ก็สวิตท์ if clause ไปที่ else if
โปรแกรมมีเงื่อนไขอีกนิดว่าค่า a ต้องมากกว่า 6377000 เมตร และค่า 1/f ต้องมากกว่า 293 ถ้าไม่ได้ให้รอป้อนจนป้อนค่าถูก
procedure TfrmSetEllipsoid.cmdApplyClick(Sender: TObject);
var
szEName, szECode : string;
dA, dB, dF : extended;
f1, f2 : boolean;
sql : TSQLQuery;
begin
try
sql := TSQLQuery.Create(nil);
sql.Database := FDBCon;
sql.Transaction := FTrans;
szEName := trim(dbcboEllipsoidName.Text);
szECode := trim(dbtxtEllipsoidCode.Text);
if (szEName <> '') and (szECode <> '') then
begin
szECode := Trim(dbtxtEllipsoidCode.Text);
f1 := trystrtofloat(dbtxtSemiMajorAxis.Text, dA);
f2 := trystrtofloat(dbtxtFlattening.Text, dF);
dB := dA - dA * 1 / dF;
if (FNewRecordState) then
begin
if (f1 and (dA > 6377000)) and (f2 and (df > 293)) then
begin
sql.Close;
sql.SQL.Clear;
sql.SQL.Text := 'INSERT INTO ELLIPSOIDS (NAME,CODE,A,B,INV_F)'
+ ' VALUES (:NAME,:CODE,:A,:B,:INV_F)';
sql.Params.ParamByName('NAME').AsString := szEName;
sql.Params.ParamByName('CODE').AsString := szECode;
sql.Params.ParamByName('A').AsFloat := dA;
sql.Params.ParamByName('B').AsFloat := dB;
sql.Params.ParamByName('INV_F').AsFloat := dF;
sql.ExecSQL;
cmdApply.Enabled := False;
cmdNew.Enabled := true;
FTrans.CommitRetaining;
FNewRecordState := false;
end
else if not(f1 and (dA > 6377000)) then
begin
MessageDlg ('Warning', 'Semi-major axis must be the number and its value must > 6,377,000 m.?', mtConfirmation,
[mbOK],0);
dbtxtSemiMajorAxis.SetFocus;
end
else if not (f2 and (df > 297)) then
begin
MessageDlg ('Warning', 'Flattening must be the number and its value must > 297 m.?', mtConfirmation,
[mbOK],0);
dbtxtFlattening.SetFocus;
end;
end
else
begin
sql.Close;
sql.SQL.Clear;
sql.SQL.Text := 'UPDATE ELLIPSOIDS SET NAME=:NAME,'
+ 'A=:A,B=:B,INV_F=:INV_F WHERE CODE=:CODE';
sql.Params.ParamByName('NAME').AsString := szEName;
sql.Params.ParamByName('CODE').AsString := szECode;
sql.Params.ParamByName('A').AsFloat := dA;
sql.Params.ParamByName('B').AsFloat := dB;
sql.Params.ParamByName('INV_F').AsFloat := dF;
sql.ExecSQL;
cmdApply.Enabled := False;
FTrans.CommitRetaining;
end;
end;
finally
sql.Free;
end;
end;
มาลองรันโปรแกรม ลองคลิกไปที่ลูกศรขวาจนถึงรูปทรงรี “WGS 72” ลองคลิกที่ปุ่ม “Delete…” โปรแกรมจะถามยืนยันตอบ OK
เมื่อลบเสร็จโปรแกรมจะเลื่อนไปที่ record แรกอัตโนมัติ ลองเลื่อนลูกศรไปดูว่า WGS 72 ยังอยู่หรือไม่ จะไม่เห็น ต่อไปลองมาแก้ไขค่ารูปทรงรีดู
สนใจพัฒนาโปรแกรมบน Lazarus มากเลยครับ แต่เวลาพัฒนาโปรแกรมแล้วผมสั่งพิมพ์ข้อความภาษาไทย อักษรภาษาอังกฤษออกครับแต่ อักษรภาษาไทยไม่สามารถพิมพ์ออกมาได้ กลับเป็นช่องว่าง ๆ เลยครับ ไม่ทราบจะแก้ยังไงดีครับ กราบขอบพระคุณมา ณ โอกาสนี้ด้วยครับ
ขอรายละเอียดอีกนิดว่า print ผ่าน component ไหน หรือผ่านจาก Win API เช่น TextOut ถือว่ามาปรึกษาและแลกเปลี่ยนประสบการณ์ก็แล้วกัน เพราะ Lazarus ที่ผมเขียนอยู่ไม่ใช่ Delphi เมื่อก่อน ที่เคยใช้งานมารอบด้าน ผมลองตรงไหนแล้ว work ใน Lazarus ก็จะนำมาเขียนครับ ถ้ามี snippet code มา post ลงก็ดี
ผมของศึกษาพัฒนาโปรแกรมภายใต้ระบบ Ubuntu 9.11 PE ครับ และใช้ตัวรายงานของ RazReport ครับ หรือแม่แต่คำสั่ง Printer.Printer ภาษาไทยก็ไม่ออกครับ ขอบคุณครับ
ขอเวลาสักพักใหญ๋ๆ ผมจะลองติดตั้ง component ตัวนี้แล้วลองดูภายใต้สภาวะแวดล้อม Ubuntu เช่นเดียวกัน
ขอเป็นกำลังใจให้ครับ
ขอบคุณครับ
ขอโทษที ผมติดภาระกิจเข้าไปทำงานในเมืองมะริด พม่าประมาณ 2 อาทิตย์เพิ่งกลับมา ที่พม่าอย่าถามเรื่อง internet ยากมาก การสื่อสารก็ยาก ยังไงๆผมมีเวลาช่วงปีใหม่จะพยายามดูครับผม