Delphi提供了功能强大的 DBGrid组件,以方便进行数据库应用程式设计。不过如果我们仅仅利用DBGrid组件,每一个获得焦点(Grid)只是个简单的文本编辑框,不方便用户输入数据。Delphi也提供了一些其他数据组件来方便用户输入,比如DBComboBox,DBCheckBox等组件,但这些组件却没有DBGrid功能强大。Delphi能不能象Visual Foxpro那样让DBGrid中获得焦点网格能是其他可视数据组件以方便用户呢?其实我们能通过在DBGrid中插入其他可视组件来实现这一点。

Delphi对DBGrid处理的内部机制,就是在网格上浮动一个组件——DBEdit组件。你输入数据的网格其实是浮动DBEdit组件,其他未获得焦点地方不过是图像罢了。所以,在DBGrid中插入其他可视组件就是在网格上浮动一个可视组件。因此所有组件,包括从简单的DbCheckBox到复杂的对话框,都能在DBGrid中插入。下面就是个怎么在DBGrid中插入DBComboBox组件的步骤,采用同样的办法能插入其他组件。

1、 在Delphi 4.0中新建一个项目。

2、 分别拖动的Data Access组件板上DataSource、Table,Data Controls组件板上DBGrid,DBComboBox四个组件到Form1上。

3、 设置各个组件的属性如下:

rcf1对象 属性 设定植
Form1 Caption  在DBGrid中插入SpinEdit组件示例
DataSource1 DataSet Table1
Table1 DatabaseName DBDEMOS
  TableName teacher.DBF
  Active True
DBGrid1 DataSource DataSource1
DBComboBox1 DataField SEX
  DataSource DataSource1
  Visible False
  Strings Items.    男| 女

意:我在这里用了Teacher.dbf,那是反映教职工的性别,只能是“男”或是“女”。

4、 DrawDataCell事件是绘制单元格,当获得焦点网格所对应的字段和组合框所对应的字段一致时,移动组合框到获得焦点的网格上,并且
使组合框可视,从而达到在DBGrid指定列上显示DBComboBox的功能。设置DBGrid1的OnDrawDataCell事件如下:
procedure TForm1.DBGrid1DrawDataCell(Sender: TObject; const Rect: TRect; Field: TField; State: TGridDrawState);
begin
  if (gdFocused in State) then
  begin
    if (Field.FieldName = DBComboBox1.DataField ) then
    begin
      DBComboBox1.Left := Rect.Left + DBGrid1.Left;
      DBComboBox1.Top := Rect.Top + DBGrid1.top;
      DBComboBox1.Width := Rect.Right - Rect.Left;
      DBComboBox1.Height := Rect.Bottom - Rect.Top;
      DBComboBox1.Visible := True;
   end;
 end;
end;

5、 DBGrid指定单元格未获得焦点时不显示DBComboBox,设置DBGrid1的OnColExit事件如下:
procedure TForm1.DBGrid1ColExit(Sender: TObject);
begin
  If DBGrid1.SelectedField.FieldName = DBComboBox1.DataField then
  begin
    DBComboBox1.Visible := false;
  end;
end;

6、 当DBGrid指定列获得焦点时DrawDataCell事件只是绘制单元格,并显示DBComboBox,不过DBComboBox并没有获得焦点,数据的输入还是在单元格上进行。在DBGrid1的KeyPress事件中调用SendMessage这个 视窗系统 API函数将数据输入传输到DBComboBox上,从而达到在DBComboBox上进行数据输入。因此还要设置KeyPress事件如下:
procedure TForm1.DBGrid1KeyPress(Sender: TObject; var Key: Char);
begin
  if (key < > chr(9)) then
  begin
    if (DBGrid1.SelectedField.FieldName  =DBComboBox1.DataField) then
    begin
       DBComboBox1.SetFocus;
       SendMessage(DBComboBox1.Handle, WM_Char, word(Key), 0);
    end;
  end;
end;

程式在中文视窗系统 98,Delphi 4.015 下调试通过。希望本文能使你能更加方便快捷的研发数据库应用程式。

转载于:https://www.cnblogs.com/tecsoon/archive/2009/03/04/1403043.html

在delphi的dbgrid中插入其他可视组件_delphi教程相关推荐

  1. Delphi中将DBGRID中的内容输出到WORD中

    这是我很久以前写的一篇文章,现在将它贴出来! 在使用DELPHI开发过程中发现网上有很多的开发朋友询问关于将DBGRID中的内容导出到一个WORD中的方法.想想可以帮帮大家,所以就自己写了一个.希望对 ...

  2. FLASH CS3中的FLA形式组件制作教程

    这种组件区别于SWC组件,和CS3自带的组件一样能够双击进入组件里面编辑. //应该是CS3新增加的一种组件形态,以制作一个MyButton组件为例子. 分如下几个步骤: 1.首先创建一空白的Acti ...

  3. 如何在Excel中插入一行

    如何在Excel中插入一行 VCL组件开发及应用 http://www.delphi2007.net/DelphiVCL/html/delphi_20061221143745213.html 请问用T ...

  4. 在DBGrid中实现Copy、Paste功能 - DELPHI

    在DBGrid中实现Copy.Paste功能 - DELPHI 工具条上的Cut.Copy和Paste加速按钮,对于使用Windows下编辑器的人来说,恐怕都是非常熟悉而且不可缺少的.Delphi中的 ...

  5. 在状态栏中插入类似进度条的可视控件

    首先,在Form中放置一个状态条控件Status.调节Status.Panels,在其中插入3个状态条嵌板.第二个嵌板的参数Style设置成psOwnerDraw.这一点很重要,如果没有这样做,将永远 ...

  6. delphi RichEdit控件中插入GIF动画表情

    delphi在RichEdit控件中插入GIF动画表情 在UDP即时通讯软件中实现类似于QQ的动画表情,在richEdit控件中插入gif动画表情. 发送的时候将表情转为命令,接收之后,再将命令转换为 ...

  7. delphi 往 excel 指定单元格中插入图片

    delphi 往 excel 指定单元格中插入图片 EApp.ActiveSheet.Range['imagepath'].select; //--选定插入图片的单元格EApp.ActiveSheet ...

  8. DELPHI的DBGRID有两个难点

    DELPHI的DBGRID有两个难点: 一,每行都是一个BUTTON,且CAPTION不同 二,每行不同行高,且由用户拖动而不同高的 这两点我用CXGRID全做到了 一, procedure TFor ...

  9. 请问,怎么在DBGRID中改变CELL内容

    请问,怎么在DBGRID中改变CELL内容 Delphi / Windows SDK/API http://www.delphi2007.net/DelphiDB/html/delphi_200612 ...

  10. 往hive表中插入与导出数据方式load ,insert ,sqoop 等方式详解

    往hive数据仓库的表中导入数据,可以直接insert ,也可以选择load方式.当然也可以通过第三方工具如sqoop等将数据导入到hive当初.特别注意:hive虽然不会验证用户装载的数据和表的模式 ...

最新文章

  1. ruby中取反的问题
  2. 完全卸载SQL Server 2008 R2(转)
  3. [Logstash-input-redis] 使用详解
  4. avue form提交变为不可编辑_教程42——富文本编辑器的原理(项目)
  5. Apollo分布式配置中心在java的简单实现
  6. 企业级业务系统开发实战-序言
  7. Spring Boot 发布 jar 包转为 war 包秘籍。
  8. Java Thread 总结
  9. 利用https实现站点的访问
  10. Python+matplotlib数据可视化鼠标悬停自动标注功能实现
  11. Oracle存储过程异常
  12. visual studio code安装
  13. YYKit 源码学习使用 1
  14. html在div中数字时钟,在JS+CSS中如何实现滚动数字时钟
  15. 小封装、高通流 TVS 管 UN1K/2K/3K Series
  16. MSDOS(MBR)和GPT磁盘分区表
  17. 基于RWEQ模型的土壤风蚀模数估算及其变化归因分析、RWEQ模型相关的SCI论文撰写技巧
  18. openssl版本升级
  19. 小米4android8.0root,小米8青春版获取root权限的教程
  20. OKR 年度规划实践:如何在 2022 年做好准备

热门文章

  1. 使用POI在线预览Word
  2. 免费的json api接口(音乐、物流、地图、视频)
  3. ACM32 MCU元器件AD封装库
  4. “斗”转星移,高精度(NTP网络授时)北斗授时系统
  5. Android开发:ZXing条码扫描-竖屏解决方案
  6. 基于灰狼优化算法的线性规划问题求解matlab程序
  7. java pdf 文字_Java如何使用Java向PDF页面中添加文本
  8. 工业机器人行业应用-3C行业塔式机箱来料分拣、贴标及包装线体
  9. 【动画消消乐】HTML+CSS 自定义加载动画 069
  10. IINA+ :在IINA播放器上观看直播