在Treeview中节点的data属性中保存记录类型及其消除的办法
一、保存记录类型在data指针中:
type
Trec=record
text:string;
left,top,width,height:Integer;
end;
TPRec = ^TRec;
var
h,lh,w,tp,lt,m,firstp:Integer;
ht:THeadTreeNode;
currentnode,pnode:TTreeNode;
hh,ss,firsttext:string;
ntrec:TPrec;
begin
firsttext:=hnode.Text;
ht:=hnode;
m:=0;
while True do
begin
w:=ht.Width;
New(ntrec);
if w>0 then
begin
hh:=ht.Text;
lh:=ht.GetLevel;
h:=ht.Height;
if lh=1 then
i:=0;
//ss:='left:'+inttostr(j)+',top:'+inttostr(i)+',h:'+inttostr(h)+',w:'+inttostr(w)+',text:'+hh+',level:'+inttostr(lh);
//Memo1.Lines.Add(ss);
//build tree
if lh=1 then
currentnode:=tree.Items.Add(nil,hh)
else
begin
pnode:=findtreeitem(tree,ht.Host.Text);
currentnode:=tree.Items.AddChild(pnode,hh);
end;
ntrec^.text:=hh;
ntrec^.Top:=i;
ntrec^.Left:=j;
ntrec^.Width:=w;
ntrec^.Height:=h;
currentnode.Data:=ntrec;//CreateMemoFun(pp,hh,'leftcolumns',baNone,nil,'',j, i, w, h);
//ntrec:=TPRec(currentnode.Data);
with ntrec^ do
begin
ss:='nodename:'+hh+',left:'+inttostr(left)+',top:'+inttostr(top)+',width:'+inttostr(width)+',height:'+inttostr(Height)+',level:'+inttostr(lh);
end;
Memo1.Lines.Add(ss);
if m=0 then
firstp:=i
else
i:=firstp;
end else //跳过不可见列
w:=0;
if Assigned(ht.Child) then
begin
//tmph:=i;
i:=i+h;
getheaditems(pp,ht.Child,i,j,zh,tmph,tree);
end else
begin
j:=j+w;
zh:=i+h;
//i:=tmph;
end;
ht:=ht.Next;
m:=m+1;
if ht.Text=firsttext then
begin
Break;
end;
end;
end;
type
Trec=record
text:string;
left,top,width,height:Integer;
end;
TPRec = ^TRec;
var
tnode,fn:THeadTreeNode;
level,ss:string;
i:Integer;
begin
with TreeView1 do
begin
for I := 0 to Items.Count-1 do
begin
level:=IntToStr(items[i].Level);
if assigned(TPRec(items[i].Data)) then
begin
dispose(TPRec(items[i].Data));
Memo1.Lines.Add('已释放指针:'+items[i].Text);
end;
ss:='nodename:'+items[i].Text+',level:'+level+',sn:'+inttostr(i);
Memo1.Lines.Add(ss);
end;
end;
end;
在Treeview中节点的data属性中保存记录类型及其消除的办法的更多相关文章
- 006——VUE中的内容与属性中使用javascript表达式的方法
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- js中的访问器属性中的getter和setter函数实现数据双向绑定
嗯,之前在读js红宝书的时候,在对象那一章有介绍属性类型.第一种数据类型指的是数据属性,第二种是访问器属性.在初识vue的时候,其双向数据绑定也是基于访问器属性中的getter和setter函数原理来 ...
- IE8中li添加float属性,中英数字混合BUG
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 视图中 jquery 使用data属性
示例:<input id='username' data-id="{$val['id']}" data-userName="{$val['name']}" ...
- jsp <form>表单提交中如何在value属性中写表达式
<input type="text" name="grop_id" value="<%=rs.getString(2)%>" ...
- 多.h项目出现的问题:使用了预编译头依然出现error LNK2005:***obj已在***obj中定义与c++ error C2011: “xxx”:“class”类型重定义解决办法
使用了预编译头依然出现error LNK2005:***obj已在***obj中定义 造成该问题的可能性比较多,本人将在今后遇到时添加进来,今天先放出本人遇到的一种情况. 多重包含含有变量定义的.h文 ...
- PyQt(Python+Qt)入门:Designer组件属性编辑界面中QWidget类相关属性详解
本文适用人员:本文比较长,适合不理解Qt Designer部件属性的人员阅读或资料查找. 声明: 1.如果有人认为本文是简单的复制粘贴+翻译而成,敬请读本文最后的后记: 2.本文为老猿Python学习 ...
- HTML 5:你必须知道的data属性
原文:All You Need to Know About the HTML5 Data Attribute 译文:你必须知道HTML 5 的Data属性 译者:dwqs HTML 5的Data属性可 ...
- html 5实用特性之data属性
HTML 5之前,我们必须依赖于class和rel属性来存储需要在网站中使用的数据片段,这种做法有时会在网站的外观和实用性之间产生冲突.而HTML 5 Data属性的存在就能很好满足需要. HTML5 ...
随机推荐
- jquery字符串转json
var data; var json='[{"CityId":18,"CityName":"西安","ProvinceId&quo ...
- php优化(php.ini)
PHP优化 ------------------------------------- 尽量选择php5.4及以上的版本,里面很多优化参数已经移除了相比以前版本 1.引擎解析优化和加速 1)eac ...
- MapReduce源码分析之LocatedFileStatusFetcher
LocatedFileStatusFetcher是MapReduce中一个针对给定输入路径数组,使用配置的线程数目来获取数据块位置的实用类.它的主要作用就是利用多线程技术,每个线程对应一个任务,每个任 ...
- 怎样在OpenStack上安装Ubuntu系统
转载请注明出处,否则将追究法律责任http://blog.csdn.net/xingjiarong/article/details/47011893 OpenStack是一个Iaas即基础即服务的云架 ...
- 使用Office 365前,企业必须要知道的10件事
目前的市场上充斥着很多关于微软Office 365的炒作,相信厂商.客户或者企业的都有自己不同的考虑.Office 365是微软云版本的Office,用户可以通过互联网创建一个帐户,付款.下载应用安装 ...
- Cross Frame Script (跨框架脚本) 攻击
一.Cross Frame Script (跨框架脚本) 攻击 什么是Cross Frame Script? 很简单,做个实验就知道了.把下面的这段HTML代码另存为一个html文件,然后用ie浏览器 ...
- ios uitableview button 获取cell indexpath.row
在iOS7下面已经无效,因为iOS7的层级关系发生变化 UITableViewCell->UITableViewCellScrollView->UITableViewCellContent ...
- PHPstorm如何导入字体主题
概要: 今天在安装phpstorm的时候发现导入字体主题时,出了问题,这个问题总是困惑我,并且曾经遇到过,没记录下来,所以想着这次记录下来吧.网上搜的稀里糊涂的,还是自己做个summary! 前提: ...
- table中tr的display属性在火狐中显示不正常,IE中显示正常
最近在作项目的时候碰到一个问题,就是需要AJAX来交互显示<tr> </tr> 标签内的东西,按照常理,对于某一单元行需要显示时,使用:display:block属性,不需要显 ...
- element-ui table 点击分页table滚动到顶部
在做项目中,碰到一个问题,table加了固定头,内容可滚动,当滚到table底边时,点击分页后还在底边 解决方法:设置table的 ref='multipleTable' //切换分页的方法加上下面这 ...