1.组件绘图原理

  Java GUI能展示出不同对话框、窗口等等组件外观的本质其实就是绘图。

  在AWT中,真正提供绘图功能的是Graphics对象,在Component中提供了三个方法来完成组件图形的绘制与刷新。

方法名 说明
Paint(Graphics g) 绘制组件的外观
update(Graphics g) 内部调用paint方法,刷新组件的外观
repaint() 调用update方法,刷新组件的外观

  一般情况下,Paint和update由系统调用,如果程序想要重新绘制组件可以使用repaint()。

2.Graphics的使用

  AWT提供了Canvas作为画布,提供了Graphics作为画笔,通过调用Graphics的setColor方法可以改变颜色。

  步骤:

    1.自定义类,继承Canvas类,重写Paint方法完成绘制。

    2.在Paint方法真正的开始绘画之前,通过调用setColor、setFont等方法设置画笔的颜色、字体等属性。

    3.调用画笔的drawXxx方法开始绘画

常用方法

方法名 说明
setColor(Color c) 设置颜色
setFont(Font font) 设置字体
drawLine() 绘画直线
drawRect() 绘画矩形
drawRoundRect() 绘画圆角矩形
drawOval() 绘画椭圆形
drawPolygon() 绘画多边形
drawArc() 绘画圆弧
drawPolyLine() 绘画折线
fillRect() 填充矩形
fillRoundRect() 填充圆角矩形
fillOval() 填充椭圆
fillPolygon() 填充多边形
fillArc() 填充圆弧
drawImage() 绘画位图
 1 import javax.swing.*;
2 import java.awt.*;
3 import java.awt.event.ActionEvent;
4 import java.awt.event.ActionListener;
5 import java.awt.event.WindowAdapter;
6 import java.awt.event.WindowEvent;
7
8 public class simpleDrawDemo {
9 private final String RECT_SHAPE = "rect";
10 private final String OVAL_SHAPE = "oval";
11 private String shape = "";
12
13 Frame frame = new Frame("简单绘图实验");
14
15 Button rect = new Button("绘制矩形");
16 Button oval = new Button("绘制椭圆");
17
18 private class MyCanvas extends Canvas{
19 @Override
20 public void paint(Graphics g){
21 if (shape.equals(RECT_SHAPE)){
22 g.setColor(Color.PINK);
23 g.drawRect(100,100,300,200);
24 }else if (shape.equals(OVAL_SHAPE)){
25 g.setColor(Color.PINK);
26 g.drawOval(100,100,300,200);
27 }
28 }
29 }
30
31 MyCanvas canvas = new MyCanvas();
32
33 public void init(){
34 rect.addActionListener(new ActionListener() {
35 @Override
36 public void actionPerformed(ActionEvent e) {
37 shape = RECT_SHAPE;
38 canvas.repaint();
39 }
40 });
41
42 oval.addActionListener(new ActionListener() {
43 @Override
44 public void actionPerformed(ActionEvent e) {
45 shape = OVAL_SHAPE;
46 canvas.repaint();
47 }
48 });
49
50 frame.addWindowListener(new WindowAdapter() {
51 @Override
52 public void windowClosing(WindowEvent e) {
53 System.exit(0);
54 }
55 });
56 canvas.setPreferredSize(new Dimension(600,400));
57 Box buttonBox = Box.createHorizontalBox();
58 buttonBox.add(rect);
59 buttonBox.add(oval);
60 frame.add(canvas,BorderLayout.NORTH);
61 frame.add(buttonBox,BorderLayout.SOUTH);
62
63 frame.pack();
64 frame.setVisible(true);
65 }
66
67 public static void main(String[] args) {
68 new simpleDrawDemo().init();
69 }
70 }

AWT08-绘图的更多相关文章

  1. Canvas绘图之平移translate、旋转rotate、缩放scale

    画布操作介绍 画布绘图的环境通过translate(),scale(),rotate(), setTransform()和transform()来改变,它们会对画布的变换矩阵产生影响. 函数 方法 描 ...

  2. 用html5的canvas和JavaScript创建一个绘图程序

    本文将引导你使用canvas和JavaScript创建一个简单的绘图程序. 创建canvas元素 首先准备容器Canvas元素,接下来所有的事情都会在JavaScript里面. <canvas ...

  3. echarts+php+mysql 绘图实例

    最近在学习php+mysql,因为之前画图表都是直接在echart的实例demo中修改数据,便想着两相结合练习一下,通过ajax调用后台数据画图表. 我使用的是echart3,相比较第二版,echar ...

  4. html5 canvas常用api总结(二)--绘图API

    canvas可以绘制出很多奇妙的样式和美丽的效果,通过几个简单的api就可以在画布上呈现出千变万化的效果,还可以制作网页游戏,接下来就总结一下和绘图有关的API. 绘画的时候canvas相当于画布,而 ...

  5. HTML5_04之SVG绘图

    1.关于Canvas绘制图像: 问题:需要绘制多张图片时,必须等待所有图片加载完成才能开始绘制:而每张图片都是异步请求,彼此没有先后顺序,哪一张先加载完成完全无法预测: 方案: var progres ...

  6. HTML5 学习总结(四)——canvas绘图、WebGL、SVG

    一.Canvas canvas是HTML5中新增一个HTML5标签与操作canvas的javascript API,它可以实现在网页中完成动态的2D与3D图像技术.<canvas> 标记和 ...

  7. AR创意分享:儿童涂鸦遇上程序绘图

    第一节 临摹 小明经常临摹同桌小美的画作. 美术课上,老师表扬了小美的新作. 图1.1 小美的作品<蒙娜·毛虫的微笑> 临,是照着原作画:摹,是用薄纸张蒙在原作上面画. 第二节 借画 小明 ...

  8. C# 一段绘图代码 在form_load事件不能显示图

    今天无意将一段绘图代码 写在form_load事件了,结果不能显示绘图.(代码:Graphics g = this.CreateGraphics();Pen pen = new Pen(Color.R ...

  9. HTML5学习总结——canvas绘制象棋(canvas绘图)

    一.HTML5学习总结——canvas绘制象棋 1.第一次:canvas绘制象棋(笨方法)示例代码: <!DOCTYPE html> <html> <head> & ...

  10. Windows Form调用R进行绘图并显示

    R软件功能非常强大,可以很好的进行各类统计,并能输出图形.下面介绍一种R语言和C#进行通信的方法,并将R绘图结果显示到WinForm UI界面上. 1 前提准备 安装R软件,需要安装32位的R软件,6 ...

随机推荐

  1. 你真的能分清putc()函数和fputc()函数吗?

    最近小编在讲关于C语言文件部分内容,讲到了fputc()函数.前面在讲字符串的时候,我们还学习过putc()函数,我们知道,putc()函数一般用于标准输出,fputc()函数一般用于文件读写.刚才呢 ...

  2. Apache Flink Dashboard未授权访问导致任意Jar包上传漏洞

    漏洞危害 攻击者无需Flink Dashboard认证,通过上传恶意jar包 csdn-[漏洞复现]Apache Flink任意Jar包上传导致远程代码执行 freebuf-Apache Flink ...

  3. 微信公众号获取openid(php实例)

    微信公众号获取openid 公众号获取openid的方法跟小程序获取openid其实是一样的,只是code获取的方式不一样 小程序获取code: 用户授权登录时调用wx.login即可获取到code ...

  4. mysql官网下载yum

    1.进入mysql官网 2.下载页面最下方的社区下载 3.找到yum库 下载: 7.安装.rpm[root@test tools]# rpm -ivh mysql80-community-releas ...

  5. 【硬件】HDMI接口HPD原理

    目录 一.什么是HPD? 二.HDMI的HPD(热插拔)原理 三.HDMI源端对HPD信号有什么要求? 由于项目需要通过HDMI获取EDID的数据,需要学习一下其获取的工作原理,所以在这里记录下. 一 ...

  6. 遇到 ''isSort()''declared here, later in the translation unit

    在编写代码时,遇到 在原来的代码中出现这个问题 原来的代码: //3 计算排序时间 template<typename T> void testSort(string sortName, ...

  7. 使用Beyond Compare对比大篇幅文件的小技巧

    我们在编辑较大篇幅的文章时,无可避免地要经过多次的修改.有时候修改的版本过多时,我们很可能就会记不清最新版的文章对比上一版的文章,究竟修改了哪些地方.但有了Beyond Compare(Windows ...

  8. css3系列之详解box-shadow

    box-shadow box-shadow呢 是设置元素的阴影效果的,利用这个属性,可以设计很多很炫丽的效果,不信? 等下,学完,我们就来完成下面这两个效果 首先 先了解一下,box-shadow 的 ...

  9. jsp自定义错误页

    1.在可能出错页面的Page标签上errorPage="/Error.jsp"指定错误页 2.Error,jsp的page标签中isErrorPage="true&quo ...

  10. Java基础教程——模拟浏览器发送请求

    JAVA访问网页 分别测试使用get和post方法访问网页,可以收到服务器的请求,并写入到html文件中. import java.io.*; import java.net.*; import ja ...