aardio部署_aardio

本文介绍了如何在aardio中使用列表框(listbox)的交互功能,特别是关注于获取选中项的索引和文本。通过示例代码展示了如何在用户点击按钮时,获取并打印listbox的selIndex和selText。同时,文章涵盖了如何加载文件内容到列表框,以及处理Gcode文件的转换方法。
摘要由CSDN通过智能技术生成

还是分析Gcode代码用的,先前是直接循环获取一行的数据然后解析显示到listbox中,现在需要点击任意一行然后进行解析测试,如果没有选中任意一行那么就继续循环解析:

listbox中有这么个函数:win.ui.ctrl.listbox() = 列表框\n!listbox.

!listbox.cls = 设计时类名

!listbox.className = 运行时类名

!listbox.clear() = 清除列表框所有内容

!listbox.delete() = 删除当前选中项

!listbox.delete(__) = 删除指定项

!listbox.getItemText(__/*项索引*/) = 获取指定项文本

!listbox.getItemRect(__/*项索引*/) = 获取指定项区块位置\n返回::RECT() 结构体

!listbox.getAt(x,y) = 返回指定客户区坐标所在的项索引.

!listbox.add(__/*请输入文本*/) = 添加列表项到尾部

!listbox.add(__/*请输入文本*/,-1) = 添加列表项到尾部

!listbox.add(__/*请输入文本*/,1) = 添加列表项到头部

!listbox.selIndex = 获取或设置列表框当前选中项\n仅在单选模式下有效,多选模式下请使用 getSelected() setSelected() 函数

!listbox.selText = 获取当前选项的文本\n或根据指定的文本查找并改变选项

对于这些理解的不是很深,所以需要一步步实践下:

姑且会用到

mainForm.listbox.selIndex, mainForm.listbox.selText

于是在界面中增加一个按钮,用来显示哪个被点选了...

console.log(mainForm.listbox.selIndex,mainForm.listbox.selText);

blob.png

实现上面的完整代码如下:

import win.ui;

/*DSG{{*/

mainForm = win.form(text="aardio form";right=561;bottom=654)

mainForm.add(

Motion_file={cls="listbox";left=373;top=10;right=552;bottom=530;edge=1;items={};z=2};

button={cls="button";text="加载";left=16;top=542;right=173;bottom=591;z=3};

button2={cls="button";text="转换";left=197;top=541;right=551;bottom=590;z=4};

button3={cls="button";text="获取谁被点选了";left=20;top=598;right=177;bottom=647;z=5};

listbox={cls="listbox";left=11;top=9;right=361;bottom=529;edge=1;items={};vscroll=1;z=1}

)

/*}}*/

import console;

console.open()

mainForm.button3.oncommand = function(id,event){

//mainForm.msgbox( mainForm.button3.text );

console.log(mainForm.listbox.selIndex,mainForm.listbox.selText);

}

mainForm.button.oncommand = function(id,event){

//mainForm.msgbox( mainForm.button.text );

var filecontent = string.load("\res\5047.nc");

var linestr = string.split(filecontent,'')

for(i=1;#linestr;1){

//增加编码转换,这样就不会显示乱码了

mainForm.listbox.add(string.fromto(linestr[i],0,65001));

}

}

G_conv = function(str){

var delspace = string.replace(str," ","");

var letter = string.split(delspace);

var num = "";

for(i=1;#letter;1){

//如果字符为空字符则不作处理继续循环

if(letter[i] == " "){

continue ;

}

//强制转换为数字格式,不是数字则返回null,是则返回数字

var k,v = tonumber(letter[i]);

//判断是数字,或者是负号,或者是小数点?

if( (k != null) || (letter[i] == "-")|| (letter[i] == ".")){

//连接这些数字

num = num ++ letter[i];

//如果字符串末尾是数字,则直接输出数字

if(i == #letter){

//console.log(num)

mainForm.Motion_file.add(num);

num ="";

}

}else {    //不是数字,直接输出

if(num != ""){

mainForm.Motion_file.add(num);

num = "";

}

//console.log(num)

mainForm.Motion_file.add(letter[i]);

//console.log(letter[i])

}

}

}

var iItem =1;

mainForm.button2.oncommand = function(id,event){

var lineCurnum ;

mainForm.Motion_file.clear();

G_conv(mainForm.listbox.getItemText(iItem));

iItem++;

if(iItem>mainForm.listbox.count){

iItem = 1;

}

}

mainForm.listbox.wndproc = function(hwnd,message,wParam,lParam){

select(message) {

case 0x233/*_WM_DROPFILES*/ {

mainForm.listbox.clear();

var path = win.getDropFile(wParam)[1];

var filecontent = string.load(path);

var linestr = string.split(filecontent,'')

for(i=1;#linestr;1){

//增加编码转换,这样就不会显示乱码了

mainForm.listbox.add(string.fromto(linestr[i],0,65001));

}

}

else {

}

}

}

mainForm.enableDpiScaling();

mainForm.show();

return win.loopMessage();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值