⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 unit_mainbak.pas

📁 DELPHI的报表控件
💻 PAS
📖 第 1 页 / 共 3 页
字号:

Function TFormMain.IsOnlyOne(Tar : String):Boolean;
begin
  Session.GetAliasNames(TmpStrList);
  Result := TmpStrList.IndexOf(Tar)=-1;
  if not Result then
  begin
    ShowMessage('不能与已存在的别名相同');
//    PostMessage(Handle,CN_MYTEXTUNDO,0,0);
  end;
end;

procedure TFormMain.TreeView1Edited(Sender: TObject; Node: TTreeNode;
  var S: String);
begin
  if IsOnlyOne(S) then begin
    Node.Text := S;
    if S <> NodeText then
    begin
      TreeView1.Tag := 1;
      SortChildren;
    end;
  end
  else PostMessage(Handle,CN_MYTEXTUNDO,0,0);
end;

procedure TFormMain.TreeView1Editing(Sender: TObject; Node: TTreeNode;
  var AllowEdit: Boolean);
begin
  AllowEdit := (Node.Level=1) AND (Node.Data = Pointer(0));
  if AllowEdit and (TreeView1.Tag = -1) then NodeText := Node.Text;
end;

procedure TFormMain.BtnPrintClick(Sender: TObject);
begin
  if PageControl1.ActivePage=TabSheet2 then
  begin
    DBGridPrn1.LoadFromStream(BBStream);
    DBGridPrn1.Preview;
    DBGridPrn1.SaveToStream(BBStream);
  end
  else if PageControl1.ActivePage=TabSheet3 then
  begin
    DBGridPrn2.LoadFromStream(BBStream);
    DBGridPrn2.Preview;
    DBGridPrn2.SaveToStream(BBStream);
  end;
end;

procedure TFormMain.TreeView1Changing(Sender: TObject; Node: TTreeNode;
  var AllowChange: Boolean);
begin
  AllowChange := TreeView1.Tag = -1;
end;

procedure TFormMain.Apply1Click(Sender: TObject);
var
  DriveName : String;
  i:integer;
begin
  DriveName := Session.GetAliasDriverName(NodeText);
//  Session.GetAliasParams(NodeText,TmpStrList);
  TmpStrList.Clear;
  For i:=1 to ShapeEx1.RowCount-1 do
    TmpStrList.Add(ShapeEx1.Items[i,0]+'='+ShapeEx1.Items[i,1]);
  Session.DeleteAlias(NodeText);
  Session.AddAlias(TreeView1.Selected.Text,DriveName,TmpStrList);
  TreeView1.Tag := -1;
  Session.SaveConfigFile;
  TreeView1.Repaint;
end;

procedure TFormMain.SaveAs1Click(Sender: TObject);
var
  NewAlias,DriveName,NewTableName,ExtName : String;
//  Fs :  TFieldDefs;
//  Idxf : TIndexDefs;
begin
  case TreeView1.Selected.Level of
  1: begin
       NewAlias := TreeView1.Selected.Text;
       if InputQuery2('Save Name As','New Alias Name',NewAlias)
         and IsOnlyOne(NewAlias) then
       begin
         DriveName := Session.GetAliasDriverName(TreeView1.Selected.Text);
         Session.GetAliasParams(TreeView1.Selected.Text,TmpStrList);
         Session.AddAlias(NewAlias,DriveName,TmpStrList);
         if TreeView1.Selected.Index = TreeView1.Selected.Parent.Count -1 then
           TmpNode := TreeView1.Items.AddObject(TreeView1.Selected,NewAlias,Pointer(0))
         else TmpNode := TreeView1.Items.InsertObject(TreeView1.Selected.Parent.Item[TreeView1.Selected.Index+1],NewAlias,Pointer(0));
         TreeView1.Items.AddChildObjectFirst(TmpNode,'Tables',Pointer(0));
         SortChildren;
       end;
     end;
  3: begin
       NewTableName := ExtractFileName(TreeView1.Selected.Text);
       ExtName := ExtractFileExt(TreeView1.Selected.Text);
       if InputQuery2('Save Name As','New Table Name',NewTableName) then
       begin
         Session.GetTableNames(TreeView1.Selected.Parent.Parent.Text,'',True,False,TmpStrList);
         NewTableName := ExtractFileName(NewTableName);
         if TmpStrList.IndexOf(NewTableName+'.'+ExtName)>=0 then
         begin
           ShowMessage('已经存在相同名字的表名,请重新指定新表名。')
         end
         else begin
           Table2.DatabaseName := Table1.DatabaseName;
           Table2.TableName := NewTableName;
           Table2.FieldDefs.Assign(Table1.FieldDefs);
           Table2.IndexDefs.Assign(Table1.IndexDefs);
           Table2.CreateTable;
           Table2.BatchMove(Table1,batAppend);
         end;
         {RichEdit1.Lines.Add('insert into '+NewTableName+' Select * from '+TreeView1.Selected.Text);
         Button1Click(nil);
         RichEdit1.Clear;}
         TreeView1.Items.AddObject(TreeView1.Selected,NewTableName,0);
{         if ShapeEx1.Items[0,1]='STANDARD' then
         begin
//           if ExtractFileExt(NewTableName)<>ExtractFileExt(TreeView1.Selected.Text)
  //           then NewTableName := ExtractFileName(NewTableName)+ExtractFileExt(TreeView1.Selected.Text);
//           NewTableName := ExtractFileName(NewTableName);
           FileCopy2(ShapeEx1.items[3,1]+'\'+TreeView1.Selected.Text,ShapeEx1.items[3,1]+'\');
           TreeView1.Items.AddObject(TreeView1.Selected,ShapeEx1.items[3,1]+'\'+NewTableName,0);
         end
         else begin
           RichEdit1.Lines.Add('Select * from '+TreeView1.Selected.Text+' into '+NewTableName);
           Button1Click(nil);
           RichEdit1.Clear;
           TreeView1.Items.AddObject(TreeView1.Selected,ShapeEx1.items[3,1]+'\'+NewTableName,0);
         end;}
       end;
    end;
  end;
end;

procedure FileCopy2(Sou,Tar:String);
var
  SHFileOpStruct: TSHFileOpStruct;
  FromDir: PChar;
  ToDir: PChar;
begin
  GetMem(FromDir, Length(Sou)+2);
  try
    GetMem(ToDir, Length(Tar)+2);
    try
      ZeroMemory(FromDir,Length(Sou)+2);
      ZeroMemory(ToDir,Length(Tar)+2);
      StrCopy(FromDir, PChar(Sou));
      StrCopy(ToDir, PChar(Tar));
      with SHFileOpStruct do
      begin
        Wnd    := Application.Handle;   // Assign the window handle
        wFunc  := FO_COPY;  // Specify a file copy
        pFrom  := FromDir;
        pTo    := ToDir;
        fFlags := FOF_NOCONFIRMATION or FOF_SILENT or FOF_RENAMEONCOLLISION;
        fAnyOperationsAborted := False;
        hNameMappings := nil;
        lpszProgressTitle := nil;
        if SHFileOperation(SHFileOpStruct) <> 0 then
          RaiseLastWin32Error;
      end;
    finally
      FreeMem(ToDir, Length(Sou)+2);
    end;
  finally
    FreeMem(FromDir, Length(Tar)+2);
  end;
end;

procedure TFormMain.Delete1Click(Sender: TObject);
var
  FileName : String;
begin
  Table1.Close;
  Query1.Close;
  case TreeView1.Selected.Level of
  1: begin
       Session.DeleteAlias(TreeView1.Selected.Text);
       Session.SaveConfigFile;
     end;
  3: begin
       Table1.DatabaseName := TreeView1.Selected.Parent.Parent.Text;
       Table1.TableName := TreeView1.Selected.Text;
//       RichEdit1.Lines.Add(TreeView1.Selected.Text);
       Table1.DeleteTable;
     end;
{       if ShapeEx1.Items[0,1]='STANDARD' then
       begin
         FileName := ShapeEx1.items[3,1]+'\'+TreeView1.Selected.Text;
         SetFileAttributes(PChar(FileName),0);
         DeleteFile(FileName);
       end
       else begin
         RichEdit1.Lines.Add('Drop Table '+TreeView1.Selected.Text);
         Button1Click(nil);
         RichEdit1.Clear;
       end;
     end;}
  end;
  TreeView1.Selected.Delete;
end;

procedure TFormMain.SortChildren();
var
  Htm : HTreeItem;
begin
  Htm := TreeView_GetSelection(TreeView1.Handle);
  Htm := TreeView_GetParent(TreeView1.Handle,htm);
  TreeView1.Perform(TVM_SORTCHILDREN,0,Integer(Htm));
end;

procedure TFormMain.Refresh1Click(Sender: TObject);
var
  NeedSysTable : Boolean;
begin
  case TreeView1.Selected.Level of
  1 : begin
        Close1Click(nil);
        Open1Click(nil);
      end;
  2 : case TreeView1.Selected.Index of
      0: begin
           TmpNode := TreeView1.Selected;
           TreeView1.Selected.DeleteChildren;
           NeedSysTable := Session.GetAliasDriverName(TmpNode.Parent.Text)='STANDARD';
           Session.GetTableNames(TmpNode.Parent.Text,'',NeedSysTable,False,TmpStrList);
           if TmpStrList.Count>0 then
           begin
             TmpStrList.Sort;
             AddSubStrings(TmpNode,TmpStrList);
             TmpNode.Expand(False);
           end;
         end;
         else ;
       end;
    {    TmpNode := TreeView1.Selected;
        Close1Click(nil);
        Open1Click(nil);
        TreeView1.Selected := TmpNode;
        TmpNode.Expand(False);}
  end;
end;

procedure TFormMain.Panel7Resize(Sender: TObject);
begin
  DBNavigator1.Left := Panel7.ClientWidth - 318;
  BtnPrint.Left := Panel7.ClientWidth - 35;
end;

procedure TFormMain.PageControl1Change(Sender: TObject);
begin
  case PageControl1.ActivePage.PageIndex of
    1: DBNavigator1.DataSource := DataSource1;
    2: DBNavigator1.DataSource := DataSource2;
    else DBNavigator1.DataSource := nil;
  end;  
end;

procedure TFormMain.RichEdit1MouseDown(Sender: TObject; Button: TMouseButton;
  Shift: TShiftState; X, Y: Integer);
var
  P : TPoint;
begin
  P := RichEdit1.ClientToScreen(Point(X,Y));
  if Sender=RichEdit1 then PopupMenu1.Tag := 0 else PopupMenu1.Tag := 1;
  PopupMenu1.Popup(P.X,P.Y);
end;

procedure TFormMain.FormShow(Sender: TObject);
begin
  TreeView1.Selected := TreeView1.Items[0];
  TreeView1.Selected.Expand(False);
  WindowState := wsMaximized;
end;

procedure TFormMain.SpeedButton1Click(Sender: TObject);
begin
  Aboutbox.ShowModal;
end;

procedure TFormMain.New1Click(Sender: TObject);
var
  DriverType, NewAlias : string;
  List : TStrings;
  I : integer;
begin
  List := TStringList.Create;
  Session.GetDriverNames(TmpStrList);
  if InputQuery3('Create New AliasName','New DriverType',DriverType,TmpStrList) then
  begin
    Session.GetDriverParams(DriverType,TmpStrList);
    i := 1;
    Session.GetAliasNames(List);
    while List.IndexOf(DriverType+IntToStr(i))>= 0 do Inc(i);
    NewAlias :=DriverType+IntToStr(i);
    NodeText := NewAlias;
    List.Free;
    Session.AddAlias(NewAlias,DriverType,TmpStrList);
    if TreeView1.Items[0].HasChildren then
      TmpNode := TreeView1.Items.AddChildObject(TreeView1.Items[0],NewAlias,Pointer(1))
    else TmpNode := TreeView1.Items.AddChildObjectFirst(TreeView1.Items[0],NewAlias,Pointer(1));
    TreeView1.Items.AddChildObjectFirst(TmpNode,'Tables',0);
    TreeView1.Selected := TmpNode;
    TreeView1.Tag := 0;
  end;
{    ShapeEx1.ColCount := TmpStrList.Count;
    For i := 0 to TmpStrList.Count-1 do
    begin
      ShapeEx1.Clear;
      ShapeEx1.Items[i,0]:=TmpStrList[i];
     end;
  end;   }
end;

{procedure TForm1.TreeView1DblClick(Sender: TObject);
begin
  case TreeView1.Selected.Level of
  3: if (TreeView1.Selected.Parent.Text='Tables') and Table1.Active then
     begin
       TreeView1.Items.AddChildFirst( TreeView1.Selected,'Fields');
       TreeView1.Items.AddChild(TreeView1.Selected,'Indexes');
       TreeView1.Selected.Expand(False);
     end;
  end;
end;}

procedure TFormMain.CNMYTEXTUNDO(var Message: TMessage);
begin
  TreeView1.Selected.Text := NodeText;
end;

end.

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -