delphi treeview用法(DELPHI中treeview和DBgird的结合使用)
本文目录
- DELPHI中treeview和DBgird的结合使用
- delphi里TreeView1控件怎么用
- delphi TreeView1怎么用
- delphi高手前来赐教小弟吧!!万分感激关于TreeView控件的用法
- delphi 树形控件的使用
DELPHI中treeview和DBgird的结合使用
treeview的点击事件里修改DBGrid绑定的DataSet的带搏Filter啊(我当你是用ADO),SQL就写select * from 水果表,Open前把Filter写成是flag=’’,Filtered赋true,然后在treeview的点击事件里(好像有记录点击的时间不要整个控件点击的时间)将DBGrid绑定的那个DataSet控件的Filter值改为’flag=’’’+所选的值(通过时间的参数应该可以的得到)+’’’’机物游子没装Delphi没办法试,不蠢蚂祥能写的很细,抱歉
delphi里TreeView1控件怎么用
如果选中节点氏氏想做点什么可以在OnChange事件里写代码,OnChange事件的Node参数就是当前刚刚选中的节点。还有,磨改Selected属性是当前选中的歼游散节点
delphi TreeView1怎么用
例一//刷新Tree 1procedure TMainForm.RefTree();varTags:string ;RootNode0,RootNode1,RootNode2,RootNode3,RootNode4,RootNode5:TtreeNode;i:integer;beginTreeView1.Items.Clear;RootNode0:=TreeView1.Items.Add(nil,’全部’);RootNode1:=TreeView1.Items.Add(nil,’资分类’);RootNode2:=TreeView1.Items.Add(nil,’部门’);RootNode3:=TreeView1.Items.Add(nil,’情况’);RootNode4:=TreeView1.Items.Add(nil,’位置’);RootNode5:=TreeView1.Items.Add(nil,’方式’);TreeView1.Items.ImageIndex:=11;TreeView1.Items.ImageIndex:=54;TreeView1.Items.ImageIndex:=54;TreeView1.Items.ImageIndex:=54;TreeView1.Items.ImageIndex:=54;TreeView1.Items.ImageIndex:=54;RootNode0.SelectedIndex:=RootNode0.ImageIndex;RootNode1.SelectedIndex:=RootNode1.ImageIndex;RootNode2.SelectedIndex:=RootNode2.ImageIndex;RootNode3.SelectedIndex:=RootNode3.ImageIndex;RootNode4.SelectedIndex:=RootNode4.ImageIndex;RootNode5.SelectedIndex:=RootNode5.ImageIndex;//分类with DataM.q1 dobeginSQL.Clear;SQL.Add(’Select Name1 from Navtree where tag=’’分类’’ ’);Open;while not eof dobeginTreeView1.Items.AddChild(RootNode1,FieldValues);next;end;end;(此处省略365个字.....呵呵)end; 例二procedure TForm1.showtree; //showtree自定义的varmynode:ttreenode;beginwith adoquery1 dobeginclose;sql.Clear;sql.Add(’select * from aa where value = ’’1’’’);open;if recordcount 《》 0 thenbegintreeview1.Items.Add(treeview1.TopItem,fieldbyname(’核核name’).AsString);end;end;with adoquery2 dobeginclose;sql.Clear;sql.Add(’select * from aa where len(name) = 4’);open;while not eof dobeginmynode:= treeview1.Items.AddChild(treeview1.TopItem,fieldbyname(’name’好纯).AsString);with adoquery3 dobeginclose;sql.Clear;sql.Add(’select * from aa where name like ’’友氏咐’+ ’%’+ mynode.Text+ ’’’ and len(name) = 6’);open;if recordcount 《》 0 thenbeginfirst;begintreeview1.Items.AddChild(mynode,fieldbyname(’name’).AsString);next;end;end;end;next;end;end;end例三一、指标树的建立 具体方法是:创建一个数据库,设计指标表t_pub_index,包含index_id、parent_id、index_name字段,其它字段根据实际业务而定,指标名称index_name将在树型控件的节点上显示,index_id字段保存节点的唯一标识号,parent_id表示当前节点的父节点号,标识号组成了一个“链表”,记录了树上节点的结构。设计一窗体Frm_sys_index,其上放置TreeView控件tv_zb、Query控件Query1及其它指标属性显示控件。一个树的节点又包含文本(Text)和数据(Data)。Text为String类,用来显示指标或指标目录名称。Data则为无定形指针(Untyped Pointer),可以指向一个与节点相联系的数据结构,该结构与数据库指标表相应域关联,如指标ID、上级节点ID。 Query控件的表达式为: select index_id, parent_id, index_name from t_pub_index start with index_id=0 connect by prior index_id=parent_id 其中start with 和connect by 是Oracle的SQL语句的保留字,使一条记录的parent_id列的值等于前一记录的index_id列的值,并以parent_id等于0的记录开始。 建树的基本思路是: procedure TFrm_sys_index.createtree; var curValue: indexPointer; //指向与节点相联系的数据结构的指针 curNode : TTreeNode; //当前节点 curid : integer; //当前节点标识号 begin curNode := nil; curid := -1; Query_index.Open; Query_index.first; while not Query_index.Eof do begin new(curValue); With curValue^ do 将数据库指标表t_pub_index各字段值赋curValue 所指数据结构 while(curid 《》 curValue.parent_id) do //当前节点的标识号不等于当前记录的父节点号 begin curNode := curNode.parent; curid:= indexPointer(curNode.data).index_id; end; curNode := tv_zb.Items.AddChildObject(curNode, curValue^.index_name,curValue); //在当前节点上添加子节点,显示节点指标名称,所带指针指向一个与指标数据相联系的数据结构 curid := indexPointer(curNode.data).index_id; Query_index.next; end; Query_index.close; end; 二、增加、删除、修改树节点 单纯在Treeview 上增加、删除、修改节点只需用它本身提供的Treeview.Items. AddChildObject、 Treeview.Selected.Delete、Treeview.Selected.EditText等方法即可,但要相应修改数据库中的数据,必须通过递归调用同一个函数(用于删除一个选项)来遍历所选节点下的所有子节点。下面以删除节点为例介绍具体实现流程: function TFrm_sys_index.delnode(node1:TTreenode):TTreenode; var childnode:TTreenode; begin childnode:=node1.GetLastChild; //按倒序获得子项,因为删除选项时,列表会发生变化 while childnode《》nil do childnode:=delnode(childnode); //如子项不为空,进行递归调用 index_id:=inttostr(indexpointer(node1.data).index_id);//获得该节点对应指标 在数据库删除相应指标; result:=node1.parent.GetPrevChild(node1); //定位到该节点的上一节点 node1.delete; //删除树节点 end; 三、拖动树节点 拖动树节点基本上是通过建立目标项的新子项、向它复制源项、删除原项来移动选项。与上述删除操作相似,也是通过递归调用同一个函数(用于移动一个选项),按倒序移动所选节点下的所有子节点。下面是递归过程的代码: procedure TFrm_sys_index.CopyNodeUnder(treeview:TTreeview; sourcenode,targetnode:ttreenode); var newnode:ttreenode; i:integer; begin newnode:=treeview.items.addchildfirst(targetnode,’’); //建立目标项 newnode.assign(sourcenode); //复制源项属性 for i:=sourcenode.count-1 downto 0 do //递归调用,按倒序移动其所有子项 CopyNodeUnder (treeview,sourcenode.item,newnode); treeview.items.delete(sourcenode); //删除源项 end; Treeview对拖动操作提供支持,我们将组件的DragKind属性设置为dkDrag,DragMode属性设置为dmAutomatic,并为OnDragOver与OnDragDrop事件编写了处理程序。OnDragOver事件处理程序对允许移动的条件进行判断,排除需要避免的特殊情况。代码如下: procedure TFrm_sys_index.tv_zbDragOver(Sender, Source: TObject; X, Y: Integer; State: TDragState; var Accept: Boolean); var targetnode,sourcenode:TTreenode; begin targetnode:=tv_zb.getnodeat(x,y); if (Source=Sender) and (targetnode《》nil) then //保证移动在TreeView上,且目标节点不为空 begin Accept:=true; sourcenode:=tv_zb.selected; //以下代码防止用户将一个选项拖到其子项上(它会随着选项一起移动,导致死循环) while (targetnode.parent《》nil) and (targetnode 《》 sourcenode) do targetnode:=targetnode.parent; if (targetnode = sourcenode) then Accept:=false; end else Accept:=false; end; OnDragDrop事件处理程序启动前述移动过程CopyNodeUnder,修改数据库数据。此外,在大批量添加数据到Treeview中时最好使用TreeView.Items.BeginUpdate和 TreeView.Items.EndUpdate,这样能加快显示速度。大致流程如下: procedure TFrm_sys_index.tv_zbDragDrop(Sender, Source: TObject; X, Y: Integer); var targetnode,sourcenode:TTreenode; begin targetnode:=tv_zb.getnodeat(x,y); //获得源节点 sourcenode:=tv_zb.selected; //获得目标节点 修改数据库中当前节点的父节点号parent_id,使其等目标节点标识号; tv_zb.items.beginupdate; //禁用TreeView重绘操作 try copynodeunder(tv_zb,sourcenode,targetnode); //启动移动过程 tv_zb.selected:=targetnode; finally tv_zb.items.endupdate; //重新设置 end; end; 例四给你一段超级短的代码,caption字段就是你的value字段,因value是保留字,所以我改成这个了。procedure TForm1.Button1Click(Sender: TObject);varss: TStrings;beginAdoQuery1.SQL.Text := ’SELECT name,caption FROM test8 ORDER BY name’;AdoQuery1.Open;ss := TStringList.Create;while not AdoQuery1.Eof dobeginss.Add(StringOfChar(#9,(Length(Trim(AdoQuery1.FieldValues)) div 2)-1)+ AdoQuery1.FieldValues);AdoQuery1.Next;end;ShowMessage(ss.Text);ss.SaveToFile(’d:\test8.txt’);ss.Free;TreeView1.LoadFromFile(’d:\test8.txt’);end;
delphi高手前来赐教小弟吧!!万分感激关于TreeView控件的用法
建议 楼主 去看看 万一的delphi blog
treeview 我也不用的是很熟练
看了万陪脊一写的例子 ,我参考着写了这个 两层遍历的demo
应该能 帮芦拍渗到贺森你
亲 不要忘了采纳最佳哟
delphi 树形控件的使用
建议你下载一个三方控件,用里面的TdxDBTreeList来直接操作树形表。如果是自己用TreeView来创建的话,要用循环分多步操作了。1、查出父结点数据2、循环写入父结点(可以将各结点序号放入高孝SelectedIndex来做临时存储)3、循环当前已写入的父结点,并根据SeletedIndex(父结点序号)来查出属于当前序号的子结点,有数据的话 再循环写入子结点4、按上述方式循环判断下级子结点就可以创建一个树形结构表了。 对宏念弯于添加,删除等操作,也可以根据SeletedIndex结合Level来操作。如果帮助到您,请记得采纳为满意答案蔽闷哈,谢谢!祝您生活愉快! vae.la
更多文章:
richtextbox和textbox区别(VBA中“RefEdit”、“TextBox”、“RichTextBox”有什么区别)
2024年5月21日 02:50
html访问本地串口(html和js能像c#那样进行串口通信吗)
2024年3月29日 06:15
java源码是什么意思(请问一下java代码是什么意思,有什么功能呢)
2024年6月21日 08:18
jquery零基础教程(web前端零基础系统学习路线(上))
2024年8月23日 03:55
delphi treeview用法(DELPHI中treeview和DBgird的结合使用)
2024年7月21日 03:01
electronic materials(求助Advanced Electronic Materials杂志的评价)
2024年7月19日 19:35
writeline方法属于类(C#中StreamWriter类的常用方法有哪些呢)
2024年7月16日 04:09
delphi正版软件(Delphi现在还有多少人在使用,使用的原因是什么)
2024年7月24日 16:04
mongodb云数据库(紫光云数据库MongoDB版有哪些功能优势啊)
2024年7月18日 00:50