制作圆形Swing按钮(中文版)

转载 2007年10月04日 15:44:00
这是一个关于制作圆形Swing按钮的技巧。事实上,这个技巧中的知识方便的适用于任何形状的按钮,但我们只作一个圆形的按钮。当你制作一个圆形的按钮时,需要做两件事。第一件事是重载一个适当的绘画方法以画出一个圆形。第二件事是设置一些事件使得只有当你点击圆形按钮的范围中的时侯按钮才会作出响应(不是包含圆形按钮的矩形的范围中)。

下面是一个实现了圆形按钮的例程:

 
import java.awt.*;
import java.awt.geom.*;
import javax.swing.*;

public class RoundButton extends JButton {
  public RoundButton(String label) {
    super(label);

// 这些声明把按钮扩展为一个圆而不是一个椭圆。
    Dimension size = getPreferredSize();
    size.width = size.height = Math.max(size.width,
      size.height);
    setPreferredSize(size);


//这个调用使JButton不画背景,而允许我们画一个圆的背景。
    setContentAreaFilled(false);
  }

// 画圆的背景和标签
  protected void paintComponent(Graphics g) {
    if (getModel().isArmed()) {

// 你可以选一个高亮的颜色作为圆形按钮类的属性
      g.setColor(Color.lightGray);
    } else {
      g.setColor(getBackground());
    }
    g.fillOval(0, 0, getSize().width-1,
      getSize().height-1);

//这个调用会画一个标签和焦点矩形。
    super.paintComponent(g);
  }


// 用简单的弧画按钮的边界。
  protected void paintBorder(Graphics g) {
    g.setColor(getForeground());
    g.drawOval(0, 0, getSize().width-1,
      getSize().height-1);
  }


// 侦测点击事件
  Shape shape;
  public boolean contains(int x, int y) {

// 如果按钮改变大小,产生一个新的形状对象。
    if (shape == null ||
      !shape.getBounds().equals(getBounds())) {
      shape = new Ellipse2D.Float(0, 0,
        getWidth(), getHeight());
    }
    return shape.contains(x, y);
  }

// 测试程序
  public static void main(String[] args) {
// 产生一个带‘Jackpot’标签的按钮。   
    JButton button = new RoundButton("Jackpot");
    button.setBackground(Color.green);

// 产生一个框架以显示这个按钮。
    JFrame frame = new JFrame();
    frame.getContentPane().setBackground(Color.yellow);
    frame.getContentPane().add(button);
    frame.getContentPane().setLayout(new FlowLayout());
    frame.setSize(150, 150);
    frame.setVisible(true);
  }
}

       由于我们想保留JButton的大部分功能,我们让RoundButton类继承了JButton类。在RoundButton的构造方法中,setContentAreaFilled()方法被调用。这就让按钮画了一个矩形的焦点区,但不画背景。

现在我们需要画一个圆的背景。这是通过重载paintComponent()方法实现的。那个方法使用Graphics.fillOval()方法画一个实心的圆。然后paintComponent()方法调用super.paintComponent()在这个实心圆的上面画了一个标签。

这个例子还重载了paintBorder()方法以在圆形按钮的边界上画一个边。如果你不想要边框,你也可以不重载这个方法。这个方法调用了Graphics.drawOval()方法以在圆的边界上画一个细的边框。

注意:在JDKTM 1.2.2中,当你将鼠标拖进或拖出按钮的范围时,JButton的行为有一个小BUG。理论上,当你在圆形按钮上点击鼠标然后拖动鼠标离开按钮的边界时,按钮应该改变它的外形。当你拖动鼠标进入按钮的边界内时,按钮应回复它的外形。不幸的是,包含这个行为的代码不能调用contains()方法。代替它的是只使用按钮的‘限制范围’(这是包含按钮的最小矩形范围)注意,如果你在圆形边界内轻微的拖动鼠标,也就是说离开圆形的范围但不离开边界,按钮将不会改变它的外形。

 

制作圆形Swing按钮(中文版)

       这是一个关于制作圆形Swing按钮的技巧。事实上,这个技巧中的知识方便的适用于任何形状的按钮,但我们只作一个圆形的按钮。当你制作一个圆形的按钮时,需要做两件事。第一件事是重载一个适当的绘...
  • jax
  • jax
  • 2001年10月24日 19:53
  • 755

java swing 圆形按钮

import java.awt.*;import java.awt.geom.*;import javax.swing.*; class RButton extends JButton {  publ...
  • zhengjianqi
  • zhengjianqi
  • 2008年03月11日 15:11
  • 7002

制作圆形Swing按钮[转载]

       这是一个关于制作圆形Swing按钮的技巧。事实上,这个技巧中的知识方便的适用于任何形状的按钮,但我们只作一个圆形的按钮。当你制作一个圆形的按钮时,需要做两件事。第一件事是重载一个适当的绘...
  • ceun
  • ceun
  • 2006年01月03日 15:39
  • 644

java圆形按钮的设计

java圆形按钮的设计
  • yubi123456
  • yubi123456
  • 2015年05月27日 09:58
  • 1824

一步步教你制作WPF圆形玻璃按钮

图1   1.介绍 从我开始使用vista的时候,我就非常喜欢它的圆形玻璃按钮。WPF最好的一个方面就是允许自定义任何控件的样式。用了一段时间的Microsoft Expression Bl...
  • new_smile
  • new_smile
  • 2016年05月11日 14:22
  • 4777

css纯代码实现圆边框和圆按钮

一、CSS3圆角的优点 传统的圆角生成方案,必须使用多张图片作为背景图案。CSS3的出现,使得我们再也不必浪费时间去制作这些图片了,而且还有其他多个优点:   * 减少维护的工作量。图片文件的生成...
  • qq_25107499
  • qq_25107499
  • 2015年10月12日 10:45
  • 6729

C#圆形Button——RoundButton

C#自定义圆形按钮控件
  • luzhenyuxfcy
  • luzhenyuxfcy
  • 2016年07月20日 11:36
  • 2132

JavaFX设置Button圆角

通过下面的CSS可以设置按钮为圆角。 #upButton{ /*设置背景颜色渐变*/ -fx-background-color: linear-gradient(to right,#...
  • u010889616
  • u010889616
  • 2017年08月24日 23:20
  • 1087

c#圆形自定义按钮

using System; using System.Collections.Generic; using System.ComponentModel; using System.Diagnos...
  • y18874489765
  • y18874489765
  • 2017年11月24日 15:51
  • 282

是的,就连这种Apollonius圆图案也很容易做成GIF动画的形式

做成动画不难; 而且这种图案的绘制对内存要求不高。
  • stereohomology
  • stereohomology
  • 2015年05月17日 09:38
  • 907
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:制作圆形Swing按钮(中文版)
举报原因:
原因补充:

(最多只允许输入30个字)