鼠标拖拽移动Java界面组件

  默认的,Frame或者JFrame自身已经实现了鼠标拖拽标题栏移动窗口的功能。

  只是,当你不满意java的JFrame样式,隐藏了标题栏和边框,又或者干脆直接使用JWindow,那你又该怎么实现鼠标拖拽移动窗口的目的呢?最开始,我简单的在mouseDragged方法里frame.setLocation(e.getX(), e.getY()),结果,frame拖拽的时候不停地闪烁,位置在屏幕上不断跳动。后来网上查资料,找到了答案。

这里给一个简单的示例,一看就明白:

  1 package com.jebysun.test.globalhotkey;
  2
  3 import java.awt.Color;
  4 import java.awt.Cursor;
  5 import java.awt.Point;
  6 import java.awt.event.MouseEvent;
  7
  8 import javax.swing.JLabel;
  9 import javax.swing.JWindow;
 10 import javax.swing.event.MouseInputListener;
 11
 12 /**
 13  * 自定义程序窗口,鼠标可拖拽移动其位置。
 14  * @author Jeby Sun
 15  *
 16  */
 17 public class MyFrame extends JWindow {
 18
 19     private static final long serialVersionUID = 1L;
 20
 21     JLabel titleLbl;
 22
 23     public MyFrame() {
 24         //设置背景颜色不能直接调用其setBackground方法,而要设置其ContentPane的背景颜色。
 25         this.getContentPane().setBackground(new Color(0x99FF66));
 26         this.setBounds(100,100,600,400);
 27         this.setLayout(null);
 28
 29         titleLbl = new JLabel("  自定义窗口标题栏");
 30         titleLbl.setOpaque(true);
 31         titleLbl.setBackground(new Color(0x66CC00));
 32         titleLbl.setBounds(0, 0, 600, 30);
 33         this.add(titleLbl);
 34         //鼠标事件处理类
 35         MouseEventListener mouseListener = new MouseEventListener(this);
 36         titleLbl.addMouseListener(mouseListener);
 37         titleLbl.addMouseMotionListener(mouseListener);
 38
 39         this.setVisible(true);
 40     }
 41
 42     /**
 43      * 鼠标事件处理
 44      * @author Jeby Sun
 45      *
 46      */
 47     class MouseEventListener implements MouseInputListener {
 48
 49         Point origin;
 50         //鼠标拖拽想要移动的目标组件
 51         MyFrame frame;
 52
 53         public MouseEventListener(MyFrame frame) {
 54             this.frame = frame;
 55             origin = new Point();
 56         }
 57
 58         @Override
 59         public void mouseClicked(MouseEvent e) {}
 60
 61         /**
 62          * 记录鼠标按下时的点
 63          */
 64         @Override
 65         public void mousePressed(MouseEvent e) {
 66              origin.x = e.getX();
 67              origin.y = e.getY();
 68         }
 69
 70         @Override
 71         public void mouseReleased(MouseEvent e) {}
 72
 73         /**
 74          * 鼠标移进标题栏时,设置鼠标图标为移动图标
 75          */
 76         @Override
 77         public void mouseEntered(MouseEvent e) {
 78             this.frame.setCursor(Cursor.getPredefinedCursor(Cursor.MOVE_CURSOR));
 79         }
 80
 81         /**
 82          * 鼠标移出标题栏时,设置鼠标图标为默认指针
 83          */
 84         @Override
 85         public void mouseExited(MouseEvent e) {
 86             this.frame.setCursor(Cursor.getPredefinedCursor(Cursor.DEFAULT_CURSOR));
 87         }
 88
 89         /**
 90          * 鼠标在标题栏拖拽时,设置窗口的坐标位置
 91          * 窗口新的坐标位置  = 移动前坐标位置+(鼠标指针当前坐标-鼠标按下时指针的位置)
 92          */
 93         @Override
 94         public void mouseDragged(MouseEvent e) {
 95             Point p = this.frame.getLocation();
 96             this.frame.setLocation(
 97                 p.x + (e.getX() - origin.x),
 98                 p.y + (e.getY() - origin.y));
 99         }
100
101         @Override
102         public void mouseMoved(MouseEvent e) {}
103
104     }
105
106
107     public static void main(String[] args) {
108         new MyFrame();
109     }
110
111 }
时间: 2024-12-28 11:59:54

鼠标拖拽移动Java界面组件的相关文章

atitit.D&D drag&drop拖拽文件到界面功能 html5 web 跟个java swing c#.net c++ 的总结

atitit.D&D drag&drop拖拽文件到界面功能 html5 web 跟个java swing c#.net c++ 的总结 1. DND的操作流程 1 2. Html5 注解事件 document.dragover >>preventDefault 1 3. 代码(js) 1 4. C++ 实现拖曳 2 5. QT拖拽功能简介 - pcsuite的专栏 - 博客频道 - CSDN.NET.htm 2 1. DND的操作流程 Dragenter 事件::更改提示的颜色

JavaScript鼠标拖拽特效及相关问题总结

#div1{width:200px;height:200px;background:red;position:absolute;} #div2{width:200px;height:200px;background:green;position:absolute;left:300px;} <div id="div1">原来的 普通拖拽</div> <div id="div2">继承的 限制范围拖拽</div> wind

unity 鼠标拖拽物体实现任意角度自旋转

主要涉及函数 Input.GetAxis(“Mouse x”) 可取得鼠标横向(x轴)移动增量 Input.GetAxis(“Mouse y”) 可取得鼠标竖向(y轴)移动增量 通过勾股定理获取拖拽长度,长度越长旋转越快 在project setting--Input 可以设置 直接上代码,看了就明白了 1 using UnityEngine; 2 using System.Collections; 3 4 public class startRoate : MonoBehaviour 5 {

一款基于jQuery的支持鼠标拖拽滑动焦点图

记得之前我们分享过一款jQuery全屏广告图片焦点图,图片切换效果还不错.今天我们要分享另外一款jQuery焦点图插件,它的特点是支持鼠标拖拽滑动,所以在移动设备上使用更加方便,你只要用手指滑动屏幕即可切换图片. 在线预览   源码下载 实现的代码. html代码: <div class="main_visual"> <div class="flicking_con"> <a class="on" href=&quo

js实现鼠标拖拽div-------Day44

如果去问这样一个问题"你觉得鼠标操作简单,还是键盘操作简单",相信会有多数人都会回答鼠标吧,毕竟键盘按钮那么多,如果手小了或者手法不规范了,太容易出问题了,也对操作的速度和有效性是大大的降低了,当然不可否认,会有那么一批人,操作起键盘来完全可以忽略鼠标的,但这些都应该是骨灰级别的了吧,起码我现在的层次还接触不到,只能向往. 然而,当面对这么一个问题时,我突然有点纠结,因为毕竟以前我也是那么想的,但是这次开发让我是大跌眼镜,键盘操作我在开发中,我只能判定其按键是否按键,然后根据不同按键进

JS Event 鼠标拖拽事件

<!DOCTYPE html><html> <head>        <meta charset="UTF-8">        <title>JS Event鼠标拖拽事件</title>                <style>            #box{width:200px;height:200px;background:#000;position:absolute;}       

鼠标拖拽模块

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Typ

jquery鼠标拖拽效果分享

//html代码部分 <!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="../js/jquery-1.11.1.js"></script> </head> <style> body

鼠标拖拽多选功能

<!DOCTYPE html><html><head> <meta charset="UTF-8"> <title>鼠标拖拽多选功能</title> <script src="https://cdn.bootcss.com/jquery/1.10.2/jquery.min.js"></script> <style type="text/css"&