Delphi

本类阅读TOP10

·分布式网络考试系统原型分析及实现
·游戏外挂设计技术探讨①
·使用HOOK随心监视Windows
·Delphi 水晶报表打包解决
·试题库开发中非文本数据的处理
·如何将几个DBGRID里的内容导入同一个EXCEL表中....的问题
·如何使用Delphi设计强大的服务器程序
·工人线程中关闭窗体的实现
·用DLL方式封装MDI子窗体。
·支持XP下托盘栏气球提示的托盘单元

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
DBGrid中用光标键控制Cell

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

{////////////////////////
//                     //
//     Grids549        //
//                     //
//   14:33 2005-2-17   //
//                     //
}////////////////////////
unit Grids549;

interface

uses
  DBGrids, Classes, Windows;

type
  TDBGrid549 = class(TDBGrid)
  public
    property InPlaceEditor;
  end ;
 
procedure CursorCtrl(Sender: TObject; var Key: Word; Shift: TShiftState); 

implementation

{ TDBGrid549 }

procedure CursorCtrl(Sender: TObject; var Key: Word;
  Shift: TShiftState);
{
Warn: This procedure may change VK_RIGHT and VK_LEFT to 0

Call this in DBGridKeyDown procedrue
eg:
procedure TForm1.DBGrid1KeyDown(Sender: TObject; var Key: Word;
  Shift: TShiftState);
begin
  Grids549.CursorCtrl(Sender, Key, Shift);
end;
}
var
  GridEditorMode: Boolean;
begin
  if Shift <> [] then Exit;
  if (Key <> VK_RIGHT) and (Key <> VK_LEFT) then
    Exit;
  GridEditorMode := TDBGrid(Sender).EditorMode;
  if not GridEditorMode then
    TDBGrid(Sender).EditorMode := True;
 
  if Key = VK_RIGHT then begin
    if GridEditorMode and (TDBGrid549(Sender).InplaceEditor.SelStart <>
      Length(TDBGrid549(Sender).InplaceEditor.Text)) then begin
      Exit;
    end;
    //Last field, move to next record     
    if TDBGrid(Sender).SelectedIndex =
      TDBGrid(Sender).FieldCount - 1 then begin
      TDBGrid(Sender).DataSource.DataSet.Next;
      TDBGrid(Sender).SelectedIndex := 0;
    end
    else
    //Focus on next field
    if TDBGrid(Sender).EditorMode then begin
      TDBGrid(Sender).SelectedIndex := TDBGrid(Sender).SelectedIndex + 1;
    end;
  end
  else
  if Key = VK_LEFT then begin
    if GridEditorMode and(TDBGrid549(Sender).InplaceEditor.SelStart <> 0) then
      Exit;
    //First field, move to prior record
    if TDBGrid(Sender).SelectedIndex = 0 then begin
        TDBGrid(Sender).DataSource.DataSet.Prior;
        TDBGrid(Sender).SelectedIndex := TDBGrid(Sender).FieldCount - 1;
    end
    else
    //Focus on prior field
    if TDBGrid(Sender).EditorMode then begin
      TDBGrid(Sender).SelectedIndex := TDBGrid(Sender).SelectedIndex - 1;
    end;
  end;
  Key := 0;
end;

end.




相关文章

相关软件