在TDBGrid控件中为作修改过的记录进行标识!

2016-02-19 12:38 31 1 收藏

今天图老师小编给大家精心推荐个在TDBGrid控件中为作修改过的记录进行标识!教程,一起来看看过程究竟如何进行吧!喜欢还请点个赞哦~

【 tulaoshi.com - 编程语言 】

  unit testDBG;

  interface

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

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  type
    TForm1 = class(TForm)
      DBG: TDBGrid;
      ADOConnection1: TADOConnection;
      ADOTable1: TADOTable;
      DataSource1: TDataSource;
      procedure DBGDrawColumnCell(Sender: TObject; const Rect: TRect;
        DataCol: Integer; Column: TColumn; State: TGridDrawState);
      procedure DBGKeyPress(Sender: TObject; var Key: Char);
      procedure FormCreate(Sender: TObject);
    private
      { Private declarations }
    public
      { Public declarations }
    end;

  var
    Form1: TForm1;
  implementation

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  {$R *.dfm}
  type
  MyRect=array[0..200] of Tpoint;
  var
  ME:MyRect;//记录已经修改过记录的单元格的左上叫的点
  i:integer;
  Cpoint:Tpoint;//当前单元格左上角的点

  procedure TForm1.DBGDrawColumnCell(Sender: TObject; const Rect: TRect;
    DataCol: Integer; Column: TColumn; State: TGridDrawState);
  var
  J:integer;
  begin
    if (gdFocused in State) {or (gdSelected in State) or (gdFixed in state)} then
    begin
  {下面的语句是记录格当前活动单元格的左上角坐标}
      Cpoint.X:=rect.Left;
      cpoint.Y:=rect.Top;
    end;
    for J:=0 to I do
    begin
      if (rect.Top=me[j].Y) and (rect.left=me[j].X) then
      begin//判断该单元格是否存在于已修改的数组的记录中!
      dbg.Canvas.Brush.Color:=clRed;
      dbg.DefaultDrawColumnCell(rect,Datacol,column,state);
      end;
    end;
  end;

  procedure TForm1.DBGKeyPress(Sender: TObject; var Key: Char);
  {由于没有找到更好的记录点,所以如果修改的时候只按了一个按键的话将不会触发这个语句!
  因为第一次执行这个语句的时候数据还没有处于修改或者插入状态,本人只测试了修改状态,添加状态没测试过!}
  var
  J:integer;
  begin
    if dbg.DataSource.DataSet.State in [dsEdit, dsInsert] then
      begin//处于就该状态:
        for J:=0 to i do
        begin//判断该格是否已经记录了
          if (me[j].X=cpoint.X) and (me[j].Y=cpoint.Y) then
            exit;
        end;//如果没记录就把它记录下来!
        me[i].X:=cpoint.X;
        me[i].Y:=cpoint.Y;
        i:=i+1;
      end;
  end;

  procedure TForm1.FormCreate(Sender: TObject);
  begin
    I:=0;//初始化数组起点
  end;

  end.

  本人只是做了修改的测试,是成功的,这么少的代码肯定是不能符合大家的更高的需求,这里只是完成了最基本的功能,方便大家理解,有什么更高的要求当然是根据各人的需要,玩一些数字游戏罢了!大家可以把它修改成更安全,更好用的东西!

  谢谢大家的捧场!

来源:https://www.tulaoshi.com/n/20160219/1601373.html

延伸阅读
QQ空间手机标识如何修改?   1)打开手机QQ空间软件,更新至最新版本4.1.2.9,进入QQ空间首页后点击右上角的设置或点击手机菜单的设置。   2)然后点击我的手机标识,如果不想出现你的手机型号可以点击安卓或者点击不显示。  
数据库实际应用中,我们往往需要得到刚刚插入的标志值来往相关表中写入数据。但我们平常得到的真的是我们需要的那个值么? 有时我们会使用 SELECT @@Identity 来获得我们刚刚插入的值,比如下面的代码 代码一: usetempdb if exists(select*fromsys.objectswhereobject_id=object_id(N'[test1]')andtypein(...
标签: Web开发
利用ajax组件怎样能让它跟server控件交互呢,例如输出一个列表,就只有用js一条一条html的输出吗?当然不是,现在可以与datagrid交互。 注:ajax的.net组件可以到此网下载,本文用的是for .net 1.1版本的。http://ajax.schwarz-interactive.de/ 1. 在引用中添加引用Ajax.dll。(这个很废话) 2.在web.config中建立HttpHandler(这个当然是在...
树视控件在多文档中的使用 作者 5icomputer 下载源代码     自从来到我们的论坛以来,认识了很多的朋友和编程的高手,从中学到了很多知识。我看在论坛中有很多人问关于树控的问题。故将树控的一些问题写出来,以供大家参考,同时也作为近一段时间来学习的总结。 &nbs...
标签: 办公软件
不知道大家有没有这样的感觉,当你查看Excel数据表中某行记录时,由于数据表中的字段较多,需要拖动水平滚动条才能将整个表格的内容看完,这样很容易“看走眼”,不小心就会将上面一行或下面一行的内容错看成当前记录的数据。这样的数据交给领导,可是要挨批噢,其实通过下面的几行VBA代码,你就可以轻轻松松地查看记录了,操作步骤如下: ...

经验教程

602

收藏

37
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部