虚表 —— 自适应列宽

光庆 4月前 749

1、纯文本:

import win.ui;
import godking.vlistEx;
/*DSG{{*/
mainForm = win.form(text="vlistEx - table adapter";right=849;bottom=578)
mainForm.add(
vlist={cls="vlistEx";left=10;top=10;right=840;bottom=570;db=1;dl=1;dr=1;dt=1;edge=1;transparent=1;z=1}
)
/*}}*/
mainForm.show();
var t = { fields={"序号","姓名","年龄","地址","身份证"} };
for(i=1;10000;1){
    var tt={};
	tt["序号"]="[@rowindex]";  // 行序号标记是不允许编辑修改的
	tt["姓名"]="["+string.random(math.random(1,10))+"]";
	tt["年龄"]="["+string.random(math.random(1,20))+"]";
	tt["地址"]="["+string.random(math.random(1,30))+"]";
	tt["身份证"]="["+string.random(math.random(1,40))+"]";
	..table.push(t,tt);
}
mainForm.vlist.setTable(t);
mainForm.vlist.setColWidthFit();
win.loopMessage();

2、带图片:

import win.ui;
import godking.vlistEx;
/*DSG{{*/
mainForm = win.form(text="vlistEx - table adapter";right=591;bottom=439)
mainForm.add(
listview={cls="vlistEx";left=10;top=10;right=576;bottom=432;acceptfiles=1;aw=1;db=1;dl=1;dr=1;dt=1;hscroll=1;vscroll=1;z=1}
)
/*}}*/
mainForm.show();
import inet.http
var img = inet.http.get("https://img-blog.csdnimg.cn/21d6c09c237442a08ab0a110d9bd8d12.png?x-oss-process=image/resize,m_fixed,h_224,w_224");
mainForm.listview.addImg("icon",img);
mainForm.listview.setRowHeight(80);
var t = {}
for(i=1;100;1){
    ..table.push(t,{"[@rowindex]",
                "文本<img name='icon',w=20,h=20,scale=true>图片<img name='icon',w=20,h=20,scale=true>混合排版",
                "<img name='icon',full=true>图片填满单元格",
                "<img name='icon',full=true,scale=true>",
                "<img name='icon',x=0,y=0,w=20,h=20><img name='icon',x=-20,y=0,w=20,h=20><img name='icon',x=0,y=-20,w=20,h=20><img name='icon',x=-20,y=-20,w=20,h=20>图片定点放置",
                })
}
mainForm.listview.setTable(t,{"编号","混合排版","填满单元格","居中缩放","定点绘制"}/*列标题*/,/*列宽*/,1/*对齐方式*/,/*字典转为数组*/,/*字符串转为Utf8*/,/*是否克隆新表*/)
mainForm.listview.setColWidthFit();
win.loopMessage();

3、不同的表头字体:

import win.ui;
import godking.vlistEx;
/*DSG{{*/
mainForm = win.form(text="vlistEx - table adapter";right=849;bottom=578)
mainForm.add(
vlist={cls="vlistEx";left=10;top=10;right=840;bottom=570;db=1;dl=1;dr=1;dt=1;edge=1;transparent=1;z=1}
)
/*}}*/
var t = { fields={"序号","我的姓名","年龄","地址","身份证"} };
for(i=1;10;1){
    var tt={};
    tt["序号"]="[@rowindex]";  // 行序号标记是不允许编辑修改的
    tt["我的姓名"]=math.random(1000,9999)+"姓名";
    tt["年龄"]=math.random(10,99);
    tt["地址"]=math.random(1,9999999)+"这里是超长文本地址";
    tt["身份证"]=math.random(1000,9999)+"身份证";
    ..table.push(t,tt);
}
mainForm.vlist.setTable(t,,,1);
mainForm.vlist.headerBkcolor = {0xFF0000,0x00FF00,0xFFFFFF,0x0000FF}; // 单独设置表头各列背景颜色
mainForm.vlist.headerFont = { // 没有设置默认字体
    ::LOGFONT(name="宋体";point=12;color=0xFFFFFF); //单独设置某列字体
    ::LOGFONT(name="微软雅黑";point=18;color=0xFF0000); //单独设置某列字体
    ::LOGFONT(name="仿宋";point=22;bold=1;color=0x0000FF); //单独设置某列字体
    [5]=::LOGFONT(name="仿宋";point=40;bold=1;color=0x0000FF); //单独设置某列字体
}
mainForm.show();
mainForm.vlist.setColWidthFit();
win.loopMessage();


最新回复 (6)
  • mndsoft 4月前
    0 引用 2

    请问如何快速刷新整列的状态数据:

    我是循环改版图片状态,感觉没效率。

    mainForm.lsvSwitch.setColumns({"名称","DO状态","DI状态"},{scale=true} , 1);
    mainForm.lsvSwitch.addImg("SWON",$"\res\on.png")
    mainForm.lsvSwitch.addImg("SWOFF",$"\res\off.png")
    mainForm.lsvSwitch.setRowHeight(40);
    mainForm.lsvSwitch.setHeaderHeight(30)
    var t = {
        {"通道1","<img name='SWOFF',x=3,y=2,w=90,h=40>","<img name='DIOFF',w=36,h=36>" } 
        {"通道2","<img name='SWOFF',x=3,y=2,w=90,h=40>","<img name='DIOFF',w=36,h=36>" } 
        {"通道3","<img name='SWOFF',x=3,y=2,w=90,h=40>","<img name='DIOFF',w=36,h=36>" } 
        {"通道4","<img name='SWOFF',x=3,y=2,w=90,h=40>","<img name='DIOFF',w=36,h=36>" } 
        {"通道5","<img name='SWOFF',x=3,y=2,w=90,h=40>","<img name='DIOFF',w=36,h=36>" } 
        {"通道6","<img name='SWOFF',x=3,y=2,w=90,h=40>","<img name='DIOFF',w=36,h=36>" } 
        {"通道7","<img name='SWOFF',x=3,y=2,w=90,h=40>","<img name='DIOFF',w=36,h=36>" } 
        {"通道8","<img name='SWOFF',x=3,y=2,w=90,h=40>","<img name='DIOFF',w=36,h=36>" } 
        {"通道9","<img name='SWOFF',x=3,y=2,w=90,h=40>","<img name='DIOFF',w=36,h=36>" } 
        {"通道10","<img name='SWOFF',x=3,y=2,w=90,h=40>","<img name='DIOFF',w=36,h=36>" } 
        {"通道11","<img name='SWOFF',x=3,y=2,w=90,h=40>","<img name='DIOFF',w=36,h=36>" } 
        {"通道12","<img name='SWOFF',x=3,y=2,w=90,h=40>","<img name='DIOFF',w=36,h=36>" } 
    } 
    mainForm.lsvSwitch.setTable(t,false);
    mainForm.lsvSwitch.headerBkcolor = 0xE0E0E0;
    
    //定时查询
    mainForm.setInterval( 
        function(){
             mainForm.lsvSwitch.redraw(true);
    if (handle) {        
        //modbus读取数据
        v = m.readHoldingRegisters(1,0,2) 
            //转二进制
    	strDO =string.format("%012b", tonumber(v[2],16))
    	strDI =string.format("%012b", tonumber(v[1],16))
    	//逆序
    	sDO=string.reverse(strDO,true)
    	sDI=string.reverse(strDI,true)
    	//这里循环12位长度字符,根据0和1刷新虚表中的图片状态
    	for (i = 1; 12; 1) {
    		mainForm.lsvSwitch.setCellImg(i,2,sDO[[i]] ="1" ? 'SWON':'SWOFF');
    		mainForm.lsvSwitch.setCellImg(i,3,sDI[[i]] ="1" ? 'DION':'DIOFF');
        }
    
        },1000
    )


  • 光庆 4月前
    0 引用 3

    发个文件包,测试一下。

    我的想法,这样可以加快速度:

    1、开始处理之前,先 disableRedraw()

    2、因为单元格内容就是一张图片,所以可以直接给单元格赋值,简单暴力直接,不要使用修改单元格图片的方式。

          mainForm.vlist.setCellText(i,2,sDO[[i]] ="1"?"<img name='SWON',x=3,y=2,w=90,h=40>":"<img name='SWOFF',x=3,y=2,w=90,h=40>")

    3、处理完之后,再 restoreRedraw()

  • mndsoft 4月前
    0 引用 4

    请见附件,主要参考学习 axuanup的  Modbus TCP&modbus rtu协议库 上位机开发/修复04功能码

    定时读取MODBUS的 DI DO值,刷新虚表,定时读取界面会卡,正在学习线程,看看能否搞个工作线程,搞完我发上来共享学习

    上传的附件:
  • mndsoft 4月前
    0 引用 5
    如果出错,用了 enet.richeditEx库做调试信息,可以注释掉
  • mndsoft 4月前
    0 引用 6
    光庆 发个文件包,测试一下。我的想法,这样可以加快速度:1、开始处理之前,先 disableRedraw()2、因为单元格内容就是一张图片,所以可以直接给单元格赋值,简单暴力直接,不要使用修改单元格图片的方 ...
    大师这样快了不少,牛!
  • cgfriend 4月前
    0 引用 7
    这个功能非常好
返回