在DBGrid中加入Checkbox

最近因为一个项目的原因想在DBGrid加入Checkbox,当然同样的功能Ehlib已经有一个控件DBGridEh已经实现。但是我不太喜欢它因为它太复杂了,而我又是一个比较赖的人,于是就想一个简单一点的方法,后来在橙子的博客发现了一段代码,拿来一试,呵呵搞定!

我们开始吧

1、新建一个项目,在其中加入ADOConnection1,ADOQuery1,DataSetProvider1, ClientDataSet1,DataSource1,DBGrid1,设定好ADOConnection1,和ADOQuery1,DataSetProvider1的Dataset属性设置为ADOQuery1,ClientDataSet1的ProviderName设定为

DataSetProvider1,在ClientDataSet1中加入所有字段,再在其中新建一个InternalCalc类型的字段“CHECKBOX”.接下来就写代码吧

    2、

procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject;
  const Rect: TRect; DataCol: Integer; Column: TColumn; State: TGridDrawState);
const
CtrlState: array[Boolean] of Integer = (DFCS_BUTTONCHECK, DFCS_BUTTONCHECK or DFCS_CHECKED);
var
   checkBox_check:boolean;

 
 
begin

  if Column.Field.FieldName  ='CheckBox'  then
  begin
    DBGrid1.Canvas.FillRect(Rect);
    checkBox_check:=false;
    if Trim(Column.Field.AsString)='1' then checkBox_check:=true;
    DrawFrameControl(DBGrid1.Canvas.Handle,Rect, DFC_BUTTON, CtrlState[checkBox_check]);
  end else DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State);
end;

procedure TForm1.DBGrid1CellClick(Column: TColumn);
begin
  if Column.Field.FieldName  ='CheckBox'  then
  begin
    with DBGrid1.DataSource.DataSet do
    begin
      if state<>dsEdit then Edit;
     
      if Trim(Column.Field.AsString)='1' then FieldByNAME('CheckBox').AsInteger:=0 ELSE
      FieldByNAME('CheckBox').AsInteger:=1;
      Post;

    end;
  end;
end;



编译运行一下,搞定了吧。


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值