aardio 文档

aardio 范例: 树视图(treeview)控件 - 入门示例

//树视图(treeview)控件 - 入门示例
import win.ui;
/*DSG{{*/
var winform = win.form(text="aardio form";right=349;bottom=249)
winform.add(
treeview={cls="treeview";left=22;top=17;right=326;bottom=230;asel=false;bgcolor=0xF0FBFF;db=1;dl=1;dt=1;edge=1;hscroll=1;infoTip=1;vscroll=1;z=1}
)
/*}}*/

import win.ui.menu;

//选中树视图(treeview)节点变更触发 onSelChanged 事件
winform.treeview.onSelChanged = function(hItem,data,nmTreeView){
    var data  = winform.treeview.getItemData(hItem);

    if( data ) winform.text = tostring(data)
    else winform.text = winform.treeview.getItemText(hItem);    
}

//右键点击树视图(treeview)触发 onRightClick 事件
winform.treeview.onRightClick = function(hItem,data){
    winform.treeview.setSelected(hItem);

    var menu = win.ui.popmenu(winform)
    menu.add("删除",
        function(){ 
            winform.treeview.delItem(hItem)
        }
    )
    menu.popup(x,y,true);       
}

//处理树视图(treeview)通知事件,实际上上面的 onSelChanged,onRightClick 都来自控件预处理的通知事件。
winform.treeview.onnotify = function(id,code,ptr){

    if( code == 0xFFFFFFF4/*_NM_CUSTOMDRAW*/ ){ //来点自绘
        var lvcd = winform.treeview.getNotifyCustomDraw(code,ptr); 
        if( lvcd.nmcd.dwDrawStage == 1/*_CDDS_PREPAINT*/ ){
            return 0x20/*_CDRF_NOTIFYITEMDRAW*/;
        }
        elseif( lvcd.nmcd.dwDrawStage == 0x10001/*_CDDS_ITEMPREPAINT*/ ){
            select(lvcd.iLevel) {
                case 0{
                    if (lvcd.nmcd.uItemState == ( 0x10/*_CDIS_FOCUS*/ | 1/*_CDIS_SELECTED*/)) 
                        lvcd.clrText = gdi.RGB(255, 255, 255);
                    else    
                        lvcd.clrText = gdi.RGB(0, 0, 255); 
                }
                case 1 {
                    if (lvcd.nmcd.uItemState == ( 0x10/*_CDIS_FOCUS*/ | 1/*_CDIS_SELECTED*/)) 
                        lvcd.clrText = gdi.RGB(255, 255, 255);
                    else    
                        lvcd.clrText = gdi.RGB(255, 0, 0);
                }
            } 
            lvcd.update() 
            return 0/*_CDRF_DODEFAULT*/
        }
    }
}

winform.treeview.insertItem( "插入文本" )

//传入数组则循环插入多个节点,数组元素 winform.treeview.insertItem 参数 @1 支持的任何类型对象。
winform.treeview.insertItem( ["数组元素","数组元素2" ])

////插入普通表对象表示的节点,至少要用 text 或者 tagName 字段指定一个字符串
var hitem = winform.treeview.insertItem( text="程序目录" );

//插入到参数 @2 指定的节点。
var hSubItem = winform.treeview.insertItem( { text="子目录" },hitem/*父节点*/); 

/*
如果单个节点对象包含数组成员或 children 字段指向数组,
则递归调用 winform.treeview.insertItem 继续插入到新节点的子节点。
*/
var hitem = winform.treeview.insertItem( { 
    text = "下面用一个数组指定子节点"; { 
        {  text = "子节点1"  };
        {  text = "子节点2" };
        {  text = "下面用一个数组指定子节点"; {
            "a";"b";"c";{ text = "d" } 
           }
        };
    }
} ) 

import string.xml;
xmlstr =  /* 
<?xml version="1.0" encoding="utf-8"?>
<project ver="10" name="aardio工程3" libEmbed="true" icon="...">
    <file name="main.aardio" path="main.aardio" >  
    </file>
    <folder name="资源文件" path="res" embed="true">
        <file name="test.aardio" path="test.aardio" >  
    </folder>
    <folder name="库" path="lib"> </folder> 
</project> 
*/ 
xmlDoc = string.xml( xmlstr )
winform.treeview.insertItem( xmlDoc ) //直接把XML加载到树形控件中, winform.treeview.getItemData(hItem) 获取节点对应的XML数据
/*
winform.treeview.insertItem 的参数 @1 可以使用使用 string.xml 对象,
或者使用相同结构的普通数据表对象,每个节点对象必须指定 tagName 或 text 属性,
treeview按text,label,title,name,tagName的顺序确定显示标题.

每个节点可以用数组包含子节点(但节点本身必须指定tagName或text属性)
也可以使用 children 成员指向一个数组表示多个子节点

可以参考 fsys.asar.reader 提供的 treeData 函数返回的数据表,
就可以直接在 treeview 中加载并显示。
*/

winform.show() 
win.loopMessage();

Markdown 格式