博客
关于我
鼠标监听事件及画笔(AWT)
阅读量:220 次
发布时间:2019-02-28

本文共 1951 字,大约阅读时间需要 6 分钟。

1、画笔

  • Paint
import java.awt.*;public class TestPain {       public static void main(String[] args) {           new MyPain().loadFrame();    }}class MyPain extends Frame{       public void loadFrame(){           setBounds(100,100,500,500);        setVisible(true);    }    @Override    public void paint(Graphics g) {           //画笔需要有颜色,需要画画        g.setColor(Color.CYAN);        //g.drawOval(100,100,100,100);        g.fillOval(100,100,100,100);        g.setColor(Color.magenta);        g.fillRect(200,150,100,100);        //养成习惯,画笔用完要把他设置为最初的颜色    }}

2、鼠标监听:

  • 目的:想要实现鼠标画画
  • MouseListener

思路

在这里插入图片描述

package com.GUI.Lession03;import java.awt.*;import java.awt.event.MouseAdapter;import java.awt.event.MouseEvent;import java.util.ArrayList;import java.util.Iterator;public class TestMouseListener {       public static void main(String[] args) {           new MyFrame();    }}class MyFrame extends Frame{       //画画笔的时候需要监听当前位置,用集合来存储这个点    ArrayList points;    public MyFrame (){           setBounds(100,100,400,400);        setVisible(true);        //存鼠标的点        points = new ArrayList<>();        //添加鼠标监听        this.addMouseListener(new MyMouseListener());    }    @Override    public void paint(Graphics g) {           //画画,监听鼠标事件        Iterator iterator = points.iterator();        while (iterator.hasNext()){               Point point = (Point) iterator.next();            g.setColor(Color.magenta);            g.fillOval(point.x,point.y,10,10);        }    }    public void addPoints(Point point){           points.add(point);    }    //鼠标监听    private class MyMouseListener extends MouseAdapter{           //鼠标   按下  弹起       按住不放。        @Override        public void mousePressed(MouseEvent e) {               MyFrame myFrame = (MyFrame) e.getSource();   //获取资源对象的。            //这个时候我们点击桌面就会产生一个点            //这个点就是鼠标的点            myFrame.addPoints(new Point(e.getX(),e.getY()));            //每次点击鼠标都要刷新一遍            myFrame.repaint();        }    }}

转载地址:http://xgzs.baihongyu.com/

你可能感兴趣的文章
Node JS: < 一> 初识Node JS
查看>>
Node JS: < 二> Node JS例子解析
查看>>
Node Sass does not yet support your current environment: Linux 64-bit with Unsupported runtime(93)解决
查看>>
Node Sass does not yet support your current environment: Windows 64-bit with Unsupported runtime(72)
查看>>
Node 裁切图片的方法
查看>>
node+express+mysql 实现登陆注册
查看>>
Node+Express连接mysql实现增删改查
查看>>
node, nvm, npm,pnpm,以前简单的前端环境为什么越来越复杂
查看>>
Node-RED中Button按钮组件和TextInput文字输入组件的使用
查看>>
vue3+Ts 项目打包时报错 ‘reactive‘is declared but its value is never read.及解决方法
查看>>
Node-RED中Switch开关和Dropdown选择组件的使用
查看>>
Node-RED中使用exec节点实现调用外部exe程序
查看>>
Node-RED中使用function函式节点实现数值计算(相加计算)
查看>>
Node-RED中使用html节点爬取HTML网页资料之爬取Node-RED的最新版本
查看>>
Node-RED中使用JSON数据建立web网站
查看>>
Node-RED中使用json节点解析JSON数据
查看>>
Node-RED中使用node-random节点来实现随机数在折线图中显示
查看>>
Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
查看>>
Node-RED中使用node-red-contrib-image-output节点实现图片预览
查看>>
Node-RED中使用node-red-node-ui-iframe节点实现内嵌iframe访问其他网站的效果
查看>>