delphi 中 dll 傳 adoconnection 及 匯出類的代碼

來源:互聯網
上載者:User

 //================  dll   工程檔案 ======

library d;

uses
  SysUtils,
  Classes,
  ActiveX,
  OleDB, ADOInt,
  Unit1 in 'Unit1.pas' {Form1};

{$R *.res}

  exports showForm,showForm2;

begin
end.

//============  dll 裡的表單代碼 ========

unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, DB, ADODB, Grids, DBGrids, StdCtrls;

type
  TForm1 = class(TForm)
    Button1: TButton;
    DBGrid1: TDBGrid;
    ADOConnection1: TADOConnection;
    ADOQuery1: TADOQuery;
    DataSource1: TDataSource;
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;
  procedure showForm(adoC:TAdoConnection;H:Thandle);stdcall;
  function  showForm2:TFormClass; stdcall;
implementation

{$R *.dfm}

  procedure showForm(adoC:TAdoConnection;H:Thandle);
  var
     form1:Tform1;
     p:^TAdoconnection;
  begin
     application.Handle := h;

     form1 := TForm1.Create(nil);
     p := @(form1.ADOConnection1);
     p^ := adoc;
     form1.ADOQuery1.Connection := p^;    // 這裡只能這樣,不能在設計時指定
    // showmessage(p^.ConnectionString);
     form1.ShowModal;
     form1.Close;

  end;

  function showForm2:TFormClass;
  begin
    result := TForm1;
  end;

 

procedure TForm1.Button1Click(Sender: TObject);
begin
  with self.ADOQuery1 do
  begin

     sql.Clear;
     sql.Add('select * from dt_dept ');
     open;
  end;
end;

end.

 

// ==================  主程式碼 ==================

unit Unit2;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, DB, ADODB;

type
  TForm2 = class(TForm)
    ADOConnection1: TADOConnection;
    Button1: TButton;
    Button2: TButton;
    Button3: TButton;
    procedure Button1Click(Sender: TObject);
    procedure Button2Click(Sender: TObject);
    procedure Button3Click(Sender: TObject);
  private
    form1 :tform;
  public
    { Public declarations }
  end;

  procedure showForm(adoC:TAdoConnection;H:Thandle);stdcall;external 'd.dll';
  function showForm2:TFormClass;stdcall;external 'd.dll';
var
  Form2: TForm2;

implementation

{$R *.dfm}

procedure TForm2.Button1Click(Sender: TObject);
var
  p:pointer;
begin
  p := @ADOConnection1;
  showForm(ADOConnection1,self.Handle);
end;

procedure TForm2.Button2Click(Sender: TObject);
var
  tform1:TFormClass;

begin
  tform1 := showForm2;
  form1 := tform1.Create(nil) ;
  form1.Show;

end;

procedure TForm2.Button3Click(Sender: TObject);
begin
  form1.Close;
end;

end.

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.