字符串变色 ( 积分: 80 )

  • 主题发起人 主题发起人 king_213
  • 开始时间 开始时间
K

king_213

Unregistered / Unconfirmed
GUEST, unregistred user!
我用SQL语句搜索数据库表中所有包含某个(或几个)字符串的字段并且将他们显示到dbgrid中同时将这个(或这几个)字符串变一下颜色 请问该如何处理???
 
今天论坛的人很少吗? 怎么没人回答问题??
 
呵呵呵呵 我怕是有两年没到过的富翁啦,哈哈哈哈,今天又逛到这里啦,
DBGRID变色的帖子多呀,不是难题呵呵
 
不大懂 全文检索看看吧
 
我上面说的可能不太明确,我的意思是这样的:
我用SQL语句查询数据库某个表中所有包含一个或多个关键字的字段(例如 查询表中所有包含"北京"的字段 或者 查询表中所有包含"北京"或“上海”的字段)并且将他们显示在dbgrid中同时把每行内容里查询的关键字(如“北京”)变成其他颜色 请问该如何实现呀???
 
在DBGrid的OnDrawColumnCell事件里自己画.
 
就是高亮关键字嘛,DBGrid没用过,不过楼上说得应该可行。
 
能告诉我怎么画吗??
 
procedure TMainForm.DBGrid1DrawColumnCell(Sender: TObject;
const Rect: TRect; DataCol: Integer; Column: TColumn;State: TGridDrawState);
var i :integer;
begin
if gdSelected in State then Exit;
//定义表头的字体和背景颜色:
for i :=0 to (Sender as TDBGrid).Columns.Count-1 do
begin
(Sender as TDBGrid).Columns.Title.Font.Name :='宋体'; //字体
(Sender as TDBGrid).Columns.Title.Font.Size :=9; //字体大小
(Sender as TDBGrid).Columns.Title.Font.Color :=$000000ff; //字体颜色(红色)
(Sender as TDBGrid).Columns.Title.Color :=$0000ff00; //背景色(绿色)
end;
//隔行改变网格背景色:
if Query1.RecNo mod 2 = 0 then
(Sender as TDBGrid).Canvas.Brush.Color := clInfoBk //定义背景颜色
else
(Sender as TDBGrid).Canvas.Brush.Color := RGB(191, 255, 223); //定义背景颜色
//定义网格线的颜色:
DBGrid1.DefaultDrawColumnCell(Rect,DataCol,Column,State);
with (Sender as TDBGrid).Canvas do //画 cell 的边框
begin
Pen.Color := $00ff0000; //定义画笔颜色(蓝色)
MoveTo(Rect.Left, Rect.Bottom); //画笔定位
LineTo(Rect.Right, Rect.Bottom); //画蓝色的横线
Pen.Color := $0000ff00; //定义画笔颜色(绿色)
MoveTo(Rect.Right, Rect.Top); //画笔定位
LineTo(Rect.Right, Rect.Bottom); //画绿色的竖线
end;
end;
 
看LZ的意思, 好象是只把关键字变色, 如果是这样, 还真没搞过, 我只搞过关键记录(整行)变色
 
procedure TForm1.DBGridEh1DrawColumnCell(Sender: TObject;
const Rect: TRect; DataCol: Integer; Column: TColumnEh;
State: TGridDrawState);
begin
with DBGridEh1.DataSource.DataSet do //变色
begin
//DBGridEh1.
if FieldByName('cc').AsString='13' then //关键字变色
begin
DBGridEh1.Canvas.Font.Color := clred;
end
else
DBGridEh1.Canvas.Font.Color := clBlack;
end;
DBGridEh1.DefaultDrawColumnCell(Rect,DataCol,Column,State);
end;
 
如果做到像Delphi集成开发环境中的编辑器那样的效果,则不能调用DefaultDrawColumnCell,而必须全部自己画.
 
上面说的 都不是我想要的效果 请高手帮忙!!!
 
我上面说的可能不太明确,我的意思是这样的:
我用SQL语句查询数据库某个表中所有包含一个或多个关键字的字段(例如 查询表中所有包含"北京"的字段 或者 查询表中所有包含"北京"或“上海”的字段)并且将他们显示在dbgrid中同时把每行内容里查询的关键字(如“北京”)变成其他颜色 请问该如何实现呀???
 
反正你说的意思也不大好明白,不管怎样也只是个业务逻辑问题,楼上好几位弟兄已经把
关键技术都给写出来说,你只要稍微改改代码就行了,呵呵
 
能有高手 帮我谢谢代码吗??
 
dfwlogo.gif
 

Similar threads

回复
0
查看
877
不得闲
回复
0
查看
1K
不得闲
S
回复
0
查看
1K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
923
SUNSTONE的Delphi笔记
S
D
回复
0
查看
931
DelphiTeacher的专栏
D
后退
顶部