aardio - 限制窗口位置和大小

效果: 

 

3e99e857772449648d09bd6cc2e40de4.gif

代码:

import win.ui;
/*DSG{{*/
var winform = win.form(text="aardio form";right=349;bottom=469)
winform.add()
/*}}*/
// 本例程由光庆编写
winform.show();
//限制宽高
import win.ui.minmax
win.ui.minmax(winform,200,200,500,500)
//限制位置
// 取屏幕宽度、高度
var screenw,screenh= win.getScreen();
// 限制窗口左边、上边、右边、下边距离
var lleft,ltop,lright,lbottom = 200,200,200,200
// 处理窗口消息
winform.wndproc = function(hwnd,message,wParam,lParam){ 
	     if message= 0x216 /*_WM_MOVING*/ {	
			m=::RECT()	
			..raw.convert(..topointer(lParam),m)
			if m.left<lleft {
				m.left=lleft;
				m.right=lleft+winform.width;
			}
			if m.top<ltop {
				m.top=ltop;
				m.bottom=m.top+winform.height;
			} 
			if m.right>screenw-lright {
				m.left=screenw-lright-winform.width;
				m.right=screenw-lright;
			} 			
			if m.bottom>screenh-lbottom {
				m.top=screenh-lbottom-winform.height;
				m.bottom=screenh-lbottom;
			} 	
			..raw.convert(m,..topointer(lParam))
        }; 
}
win.loopMessage();
Ardio是一款用于快速构建图形用户界面(GUI)的应用程序开发框架,它基于JavaScript语言,适用于Node.js环境。在Ardio中,父窗口与子窗口之间的参数传递通常通过事件系统或者对象实例共享来完成。 1. **通过事件传递**: 当创建子窗口时,可以在子窗口的构造函数中设置一个回调函数,这个函数会在父窗口触发某个特定事件时被调用。在这个函数里,你可以从父窗口传入参数。例如: ```javascript const childWindow = new ChildWindow(function(params) { console.log('Received params:', params); }); // 在父窗口触发事件并传递参数 parentWindow.emit('openChild', { someData: 'fromParent' }); ``` 2. **通过数据属性**: 另一种方式是父窗口直接将参数作为属性赋值给子窗口实例,在子窗口初始化时就可以访问到这些数据: ```javascript function ChildWindow(props) { this.props = props; } const childWindow = new ChildWindow({ dataFromParent: 'value' }); console.log(childWindow.props.dataFromParent); // 输出 'value' ``` 3. **通过对象实例**: 如果需要频繁交互的数据,可以考虑将包含参数的对象作为参数传递,并在子窗口内部维护这个对象的引用。 ```javascript class ParentData { constructor(data) { this.someData = data; } } const parentData = new ParentData({ ... }); childWindow.setData(parentData); ``` 在子窗口中,`setData`方法可以接收并处理来自父窗口的数据。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卢光庆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值