全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1661
推到 Plurk!
推到 Facebook!

点击DBgrid其中一行 如何使cells下值相同的其他行 一起被选中?

答題得分者是:Fishman
baby2321
初階會員


發表:52
回覆:165
積分:48
註冊:2005-06-11

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-05-07 02:38:55 IP:221.232.xxx.xxx 未訂閱
ADO连接正常
DBgrid显示资料也OK 每次点击DBgrid中一行资料 则该行高亮显示了
表如下:
班级 姓名
1 A君
1 B君
2 C君
2 D君
3 E君
3 F君
4 G君
4 H君
4 I君
请问 如何实现 点击时 班级相同的行 一起高亮显示?如 我点击A君 怎样实现A君和B君的行一起高亮显示?点G君 则G君 H君 I君三行一起高亮显示?

谢谢大家
編輯記錄
baby2321 重新編輯於 2007-05-07 02:40:42, 註解 無‧
Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-05-07 15:35:44 IP:59.124.xxx.xxx 未訂閱
在 DBGrid 的 On_Cell_Click 事件,但有一點點小BUG待自行修正
<textarea class="delphi" rows="10" cols="60" name="code"> procedure TForm1.DBGrid1CellClick(Column: TColumn); var Saveplace : TBookMark; CurrentID: Integer; begin DBGrid1.SelectedRows.Clear; with DBGrid1.DataSource.DataSet do begin if Active then begin CurrentID := FieldByName('id').AsInteger; DisableControls; Saveplace := GetBookmark; try First; while not eof do begin if FieldByName('id').AsInteger = CurrentID then begin DBGrid1.SelectedRows.CurrentRowSelected := True; Application.ProcessMessages; end; Next; end; GotoBookmark(SavePlace); finally FreeBookmark(SavePlace); EnableControls; end; end; end; end; </textarea>
------
Fishman
baby2321
初階會員


發表:52
回覆:165
積分:48
註冊:2005-06-11

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-05-07 23:53:19 IP:221.232.xxx.xxx 未訂閱
多谢Fishman回复
代码执行无问题 但仍然只能高亮其中一行
即不能实现 点击时 班级相同的行 一起高亮显示

我想关键是不是在这里
if FieldByName('id').AsInteger = CurrentID then
begin
DBGrid1.SelectedRows.CurrentRowSelected := True;
//这里?还是dbgrid默认每次循环时高亮只显示一行 当再次循环时 先前高亮的一行就被后来高亮的一行代替了?
Application.ProcessMessages;
end;

这里 是不是 始终和查找行相比较 自己和自己比较 是否是这样的原因


不知如何调整
感谢
編輯記錄
baby2321 重新編輯於 2007-05-07 23:55:45, 註解 無‧
baby2321 重新編輯於 2007-05-08 00:01:05, 註解 無‧
baby2321 重新編輯於 2007-05-08 00:01:27, 註解 無‧
baby2321 重新編輯於 2007-05-08 00:05:31, 註解 無‧
baby2321 重新編輯於 2007-05-08 02:37:03, 註解 無‧
Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#4 引用回覆 回覆 發表時間:2007-05-08 08:13:18 IP:59.124.xxx.xxx 未訂閱
DBGrid1.Options 的 dgRowSelect  及 dbMultiSelect  設為 True 再試試!

------
Fishman
baby2321
初階會員


發表:52
回覆:165
積分:48
註冊:2005-06-11

發送簡訊給我
#5 引用回覆 回覆 發表時間:2007-05-08 20:25:49 IP:58.48.xxx.xxx 未訂閱
 dbMultiSelect  没有设为 True  惭愧 

多谢Fishman大大
系統時間:2024-06-27 1:36:56
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!