控件的鼠标拖动和改变大小实现的思考

控件的鼠标拖动和改变大小实现的思考

WinForm应用里经常会使用一些自绘的非标准窗口来改善软件的观感,由于不再使用标准窗口的标题来和边框,那么窗口的Move和Resize的功能就需要自己来实现。在我写这个功能的时候是直接在OnMouseMove中进行Location和Size的改变。这种使用这种方式后发现在Resize和Move的时候CPU占用率有时会到100%,因为MouseMove消息的产生频率非常高,基本上鼠标每移动一个像素位置都会发出一个MouseMove消息,由于我是在MouseMove中进行Resize,那么Resize的频率也会很频繁,这在一些简单的窗口中(控件少,自绘逻辑简单)的窗口中可能问题不大,但是对于一些较复杂的窗口来说,频繁的Repaint和layout的代价是巨大的。

后来尝试在Idle Event中进行Resize这样,经过一些实验发现Idle event的触发频率比MouseMove少40%,而效果却保持不变。更好的是Idle event是根据应用程序是否空闲来决定其发生频率的,这样在系统繁忙的时候,窗口resize的反应慢一点也是可以接受的,这样可以把更多的CPU资源用于需要的计算中。

这只算记个笔记备忘吧,如果有做过自绘窗口的resize功能的欢迎一起交流讨论。:)

 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值