JPanel Redondeado

Publicado: noviembre 26, 2007 en General, NetBeans, Swing
Etiquetas:, , , ,

En una entrega anterior se vio como crear un panel semitransparente la cual era una clase que hereda de JPanelRound aqui esta el codigo fuente de este panel que tiene las esquinas redondeadas:

Panel rdondeado

import java.awt.BasicStroke;
import java.awt.Color;
import java.awt.GradientPaint;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Paint;
import java.awt.RenderingHints; import java.awt.geom.RoundRectangle2D;
import javax.swing.JPanel;

/**
*
* @author Edisoncor
*/
public class JPanelRound extends JPanel{

    private Color colorPrimario = new Color(0x666f7f);
    private Color colorSecundario = new Color(0x262d3d);
    private Color colorContorno = new Color(0x262d3d);
    private int arcw=20;
    private int arch=20;
   
    public JPanelRound() {
        super();
        setOpaque(false);
    }
   
   
     @Override
    protected void paintComponent(Graphics g) {
        Graphics2D g2 = (Graphics2D) g;
        g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING,
                RenderingHints.VALUE_ANTIALIAS_ON);
       
       
         Paint oldPaint = g2.getPaint();
          RoundRectangle2D.Float r2d = new RoundRectangle2D.Float(
                    0,0,getWidth(),getHeight()-1,getArcw(),getArch());
            g2.clip(r2d);
            g2.setPaint(new GradientPaint(0.0f, 0.0f,getColorPrimario().darker(),
                    0.0f, getHeight(),getColorSecundario().darker()));
            g2.fillRect(0,0,getWidth(),getHeight());
           
            g2.setStroke(new BasicStroke(4f));
            g2.setPaint(new GradientPaint(0.0f, 0.0f,getColorContorno(),
                    0.0f, getHeight(), getColorContorno()));
            g2.drawRoundRect(0, 0, getWidth()-2 , getHeight() -2, 18, 18);
       
        g2.setPaint(oldPaint);
        super.paintComponent(g);
    }

    public Color getColorPrimario() {
        return colorPrimario;
    }

    public void setColorPrimario(Color colorPrimario) {
        this.colorPrimario = colorPrimario;
    }

    public Color getColorSecundario() {
        return colorSecundario;
    }

    public void setColorSecundario(Color colorSecundario) {
        this.colorSecundario = colorSecundario;
    }

    public Color getColorContorno() {
        return colorContorno;
    }

    public void setColorContorno(Color colorContorno) {
        this.colorContorno = colorContorno;
    }

    public int getArcw() {
        return arcw;
    }

    public void setArcw(int arcw) {
        this.arcw = arcw;
    }

    public int getArch() {
        return arch;
    }

    public void setArch(int arch) {
        this.arch = arch;
    }
}
 

Aqui vamos a observar que se definen los siguientes atributos:

  • colorPrimario que va a representar el color de la parte superior del Panel
  • colorSecundario representa el color de la parte inferior del panel
  • colorContorno el color alrededor del panel
  • arcw representa el angulo horizontal y
  • arch que representa el angulo vertical para el Panel
comentarios
  1. […] (RSS) « JTextField con Imagen y redondeado JPanel Redondeado […]

  2. Karla dice:

    Tengo problemas con este ejemplo me marca error en copilarlo en las lineas:
    private Color colorPrimario = new Color(0×666f7f);
    private Color colorSecundario = new Color(0×262d3d);
    private Color colorContorno = new Color(0×262d3d);

  3. OctiCoCo dice:

    Los problemas de “private Color colorPrimario = new Color(0×666f7f);”
    los solucionas cambiando la “×” que aparece entre el 0 y el 6 dentro de new Color, por la equis “x”
    Saludos

  4. eduardo dice:

    cómo muestras una ventana si en tu código no hay ninguna declaración de jFrame????

  5. alceloco dice:

    jeje donde pongo esto en una class
    como lo uso….
    lo pongo en libreria y eso comose hace ayuda porfabor……..

Responder

Introduce tus datos o haz clic en un icono para iniciar sesión:

Logo de WordPress.com

Estás comentando usando tu cuenta de WordPress.com. Cerrar sesión / Cambiar )

Imagen de Twitter

Estás comentando usando tu cuenta de Twitter. Cerrar sesión / Cambiar )

Foto de Facebook

Estás comentando usando tu cuenta de Facebook. Cerrar sesión / Cambiar )

Google+ photo

Estás comentando usando tu cuenta de Google+. Cerrar sesión / Cambiar )

Conectando a %s