首页 > 代码库 > 分享一个自定义打印套打方案(二),扩展Panel,以支持鼠标随意拖动
分享一个自定义打印套打方案(二),扩展Panel,以支持鼠标随意拖动
接上一章节,本篇主要介绍一种支持鼠标随意拖动Panel内部控件位置的方法.为了简单起见,这里我们不妨就暂称我们将要扩展的Panel容器名称为 MoveControlPanel,该容器至少需要实现以下功能
1. 识别当前鼠标位置,是否处于某个内部组件的边框位置,以让鼠标显示出对应的图标(拉伸,移动…)
2.移动鼠标以改变内部某个组件的大小及坐标,
3.保存容器内每个组件的当前坐标及大小.
为了便于描述当前光标状态,我们不妨定义一个枚举.姑且称其为 EMousePointPosition, 其至少应该具有如下定义.
/// <summary> /// 光标状态 /// </summary> private enum EMousePointPosition { /// <summary> /// 无 /// </summary> None = 0, /// <summary> /// 处于拉伸右边框位置 /// </summary> MouseSizeRight = 1, /// <summary> /// 处于拉伸左边框位置 /// </summary> MouseSizeLeft = 2, /// <summary> /// 处于拉伸下边框位置 /// </summary> MouseSizeBottom = 3, /// <summary> /// 处于拉伸上边框位置 /// </summary> MouseSizeTop = 4, /// <summary> /// 处于拉伸左上角位置 /// </summary> MouseSizeTopLeft = 5, /// <summary> /// 处于拉伸右上角位置 /// </summary> MouseSizeTopRight = 6, /// <summary> /// 处于拉伸左小角位置 /// </summary> MouseSizeBottomLeft = 7, /// <summary> /// 处于拉伸右下角位置 /// </summary> MouseSizeBottomRight = 8, /// <summary> /// 鼠标拖动状态 /// </summary> MouseDrag = 9 }
未完待续
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。