html可以移动的浮动窗口

23 篇文章 0 订阅

先看例子:

http://182.92.97.72/float_suspend/


效果描述:

(1) 鼠标点击" "即可拖动;

(2)滚动网页的竖直滚动条时,该窗口的位置固定不变;

(3)无论怎么移动,该窗口不会跑到网页可视范围之外

 

关键code:

// 拖拽效果
	function drag(){
		var tags = arguments;
		// alert(tags[0].length);//长度为4
		
		for(var i=0;i<tags[0].length;i++){
			// addEvent(tags[0].get(i),'mousedown',function(e){
				$(tags[0].get(i)).bind('mousedown',function(e){
				if(trim(this.innerHTML).length == 0) e.preventDefault();
				var _this = this;
				// var diffX = e.clientX - _this.offsetLeft;
				// var diffY = e.clientY - _this.offsetTop;

				var diffX = e.clientX - $(_this).parent().get(0).offsetLeft;
				var diffY = e.clientY - $(_this).parent().get(0).offsetTop;


				//自定义拖拽区域
				var flag = false;				
				for (var i = 0; i < tags[0].length; i ++) {
					if (e.target == tags[0].get(i)) {
						flag = true;					//只要有一个是true,就立刻返回
						break;
					}
				}


				if (flag) {
					$(document).bind('mousemove',move);
					$(document).bind('mouseup',up);
				} else {
					$(document).unbind('mousemove',move);
					$(document).unbind('mousemove',up);
				}
			
			function move(e) {
	
				$('div.suspend').css("position", 'absolute');//保证移动div的标题时,div跟着移动
				scrollTop22=document.body.scrollTop;
				if(isIEtest && scrollTop22==0){//IE中
					scrollTop22=document.documentElement.scrollTop;
				}
				//alert();
				var left = e.clientX - diffX;
				var old_top = e.clientY - diffY;
				var top=old_top+scrollTop22;
				//console.log(old_top+"\t"+scrollTop22);	
				var divWidth22=$(_this).parent().get(0).offsetWidth;//div 的宽度
				var screenWidth=document.body.clientWidth;//屏幕宽度,不兼容IE
				if(isIEtest ){//IE中,isIEtest的初始化在common_util.js 中
					screenWidth=document.documentElement.clientWidth;//屏幕宽度
				}
				//console.log(left+"\t"+screenWidth);
				var rightZero=(screenWidth-divWidth22)-left;
				if(rightZero<0)//防止div跑到窗口的右边之外
				{
					left+=rightZero;
				}
				if (left < 0) {
					left = 0;
				}else if(left <= getScroll().left){
					left = getScroll().left;
				} else if (left > getInner().width + getScroll().left - $(_this).parent().get(0).offsetWidth) {
					left = getInner().width + getScroll().left- $(_this).parent().get(0).offsetWidth;
				}
				
				if (top < 0) {
					top = 0;
				}else if(top <= getScroll().top){
					top = getScroll().top
				} else if (top > getInner().height + getScroll().top - $(_this).parent().get(0).offsetHeight) {
					top = getInner().height + getScroll().top - $(_this).parent().get(0).offsetHeight;
				}


				$(_this).parent().get(0).style.left = left + 'px';
				$(_this).parent().get(0).style.top = top + 'px';
				//$(_this).parent().get(0).style.bottom= (50+old_top)+ 'px';
				if (typeof _this.setCapture != 'undefined') {
					_this.setCapture();
				} 
			}
			
			function up(e) {
				$('div.suspend').css("position", 'fixed');//保证上下移动滚动条时div保持不变,所以必须恢复为fixed
				var event_clientY=e.clientY;
				var top =event_clientY  - diffY;
				var screenHight=document.body.clientHeight;//屏幕高度,不兼容IE
				if(isIEtest ){//IE中,isIEtest的初始化在common_util.js 中
					screenHight=document.documentElement.clientHeight;//屏幕高度
				}
				var divHeight22=$(_this).parent().get(0).offsetHeight;//div 的高度
				//console.log(event_clientY+"\t "+diffY+"\t"+screenHight+"\t"+divHeight22+"\t"+document.body.scrollTop );
				var bottomZero=screenHight-divHeight22+diffY;
				//console.log(bottomZero+"\t"+top);
				if(event_clientY>bottomZero){//防止div跑到bottom以下,防止div跑出窗口之下
					//alert(111);
					top-=(event_clientY-bottomZero);
				}
				if(top<0)//top为负数,就表示div拖拽到窗口之上了
				{
					top=0;//防止div跑出窗口之上
				}
				$(_this).parent().get(0).style.top = top + 'px';//解决鼠标松开时位置突变的不正常现象
				$(document).unbind('mousemove',move);
				$(document).unbind('mouseup',up);
				if (typeof _this.releaseCapture != 'undefined') {
					_this.releaseCapture();
				}
			}


			});
		}

 源代码见附件float_suspend.zip

参考:http://huangkunlun520.blog.51cto.com/2562772/1570707

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MFC(Microsoft Foundation Classes)是一种用于开发Windows应用程序的框架,它提供了一种方便的方式来创建用户界面。在MFC中,可以在对话框上使用浮动窗口浮动窗口是一个可以在对话框上自由移动窗口。在MFC中,可以通过以下步骤使用浮动窗口: 1. 首先,在对话框上添加一个普通的窗口控件,这个控件将用作浮动窗口的容器。 2. 然后,在对话框类的.h文件中声明一个成员变量,用于存储浮动窗口的指针。例如,可以声明一个CWnd*类型的成员变量m_pFloatingWnd。 3. 在对话框类的.cpp文件中,首先在OnInitDialog()函数中获取浮动窗口的ID,并将其与步骤1中创建的窗口控件关联起来。例如,可以使用GetDlgItem()函数获取控件的指针,并将其传递给浮动窗口的Create()函数。 4. 接下来,在需要显示浮动窗口的地方,可以通过调用浮动窗口的ShowWindow()函数将其显示出来。例如,可以在某个按钮的单击事件中调用ShowWindow(SW_SHOW)来显示浮动窗口。 5. 最后,在对话框类的析构函数中,需要释放浮动窗口的资源。可以通过调用浮动窗口的DestroyWindow()函数来销毁它。 通过以上步骤,就可以在MFC的对话框上使用浮动窗口了。浮动窗口可以实现一些特殊的功能,例如显示附加的工具栏、属性窗口或其他自定义界面。使用浮动窗口可以提高用户界面的灵活性和可定制性,使应用程序更加易用和美观。 ### 回答2: MFC是Microsoft Foundation Classes的缩写,是微软提供的一种用于开发Windows应用程序的C++类库。MFC中的对话框是一种常用的窗口类型,用于显示一些简单的用户界面。浮动窗口是一种可以在对话框上以悬浮的形式显示的子窗口。 在MFC中使用浮动窗口,在对话框类中首先需要创建一个浮动窗口对象。可以在OnInitDialog()方法中创建,使用CWnd的CreateEx()函数创建一个新的窗口对象,并指定其样式和位置。然后,可以使用SetWindowPos()函数设置浮动窗口的初始位置和大小。 接下来,可以在对话框类的OnSize()方法中根据对话框的大小调整浮动窗口的位置和大小。使用CWnd的GetClientRect()函数获取对话框的客户区大小,然后使用SetWindowPos()函数重新设置浮动窗口的位置和大小。 在对话框类的OnPaint()方法中,需要调用浮动窗口对象的OnPaint()方法来绘制浮动窗口的内容。可以通过调用GetDlgItem()函数获取对话框上的浮动窗口控件的句柄,然后使用CWnd的FromHandle()函数将其转换为CWnd对象,再调用OnPaint()方法。 在对话框类的OnDestroy()方法中,需要销毁浮动窗口对象。可以使用CWnd的DestroyWindow()函数销毁浮动窗口对象,并释放相关的资源。 总之,在MFC中使用浮动窗口需要创建并控制浮动窗口对象的位置和大小,并在需要绘制内容的时候调用其相应函数进行处理。通过合理的调用和处理,可以实现在对话框上使用浮动窗口的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值