本文实例为大家分享了Java swing 仿QQ账号密码输入框,供大家参考,具体内容如下

主要思路是自己定义 AccountPanel 和 PasswordPanel 类,继承JPanel,通过 paintComponent(Graphics g) 方法重绘面板,实现目标样式。

先上效果图

正常显示效果:

鼠标放在控件上时的效果:

腾讯QQ登录界面的账号密码输入部分效果比对:

下面直接给出代码吧

AccountPanel:

import java.awt.BasicStroke;

import java.awt.Color;

import java.awt.Graphics;

import java.awt.Graphics2D;

import java.awt.RenderingHints;

import javax.swing.JPanel;

public class AccountPanel extends JPanel{

private static final long serialVersionUID = 1L;

private Color normalc=Color.LIGHT_GRAY;

private Color borderc=Color.LIGHT_GRAY;

private boolean flag=false;

public AccountPanel(){}

public AccountPanel(Color normalc,Color borderc){

this.normalc=normalc;

this.borderc=borderc;

}

public void setBorder(boolean flag){

this.flag=flag;

}

@Override

public void paintComponent(Graphics g){

super.paintComponent(g);

Graphics2D g2=(Graphics2D) g;

//设置绘图质量

g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING,RenderingHints.VALUE_ANTIALIAS_ON);

//画一个顶部两个角为圆角,底部两个角为直角的矩形

g2.setColor(Color.white);

g2.fillRoundRect(0, 0, 190, 30, 10, 10);

g2.fillRect(0, 10, 190, 17);

//为该矩形添加边框

if(flag){

g2.setStroke(new BasicStroke(2.0f));

g2.setColor(borderc);

g2.drawArc(1, 1, 10, 10, 180, -90);//绘制圆弧

g2.drawLine(5, 1, 185, 1);

g2.drawArc(179, 1, 10, 10, 90, -90);//绘制圆弧

g2.drawLine(1, 5, 1, 29);

g2.drawLine(189, 5, 189, 29);

g2.drawLine(1, 29, 190, 29);

}

else{

g2.setStroke(new BasicStroke(1.0f));

g2.setColor(normalc);

g2.drawArc(0, 0, 10, 10, 180, -90);//绘制圆弧

g2.drawLine(5, 0, 185, 0);

g2.drawArc(179, 0, 10, 10, 90, -90);//绘制圆弧

g2.drawLine(0, 5, 0, 30);

g2.drawLine(189, 5, 189, 30);

g2.drawLine(0, 30, 190, 30);

}

}

}

PasswordPanel:

import java.awt.BasicStroke;

import java.awt.Color;

import java.awt.Graphics;

import java.awt.Graphics2D;

import java.awt.RenderingHints;

import javax.swing.JPanel;

public class PasswordPanel extends JPanel{

private static final long serialVersionUID = 1L;

private Color normalc=Color.LIGHT_GRAY;

private Color borderc=Color.LIGHT_GRAY;

private boolean flag=false;

public PasswordPanel(){}

public PasswordPanel(Color normalc,Color borderc){

this.normalc=normalc;

this.borderc=borderc;

}

public void setBorder(boolean flag){

this.flag=flag;

}

@Override

public void paintComponent(Graphics g){

super.paintComponent(g);

Graphics2D g2=(Graphics2D) g;

//设置绘图质量

g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING,RenderingHints.VALUE_ANTIALIAS_ON);

//画一个顶部两个角为圆角,底部两个角为直角的矩形

g2.setColor(Color.white);

g2.fillRoundRect(0, 0, 190, 30, 10, 10);

g2.fillRect(0, 0, 190, 17);

//为该矩形添加边框

//为该矩形添加边框

if(flag){

g2.setStroke(new BasicStroke(2.0f));

g2.setColor(borderc);

g2.drawLine(1, 1, 1, 25);

g2.drawLine(189, 1, 189, 25);

g2.drawLine(1, 1, 190, 1);

g2.drawArc(1, 18, 10, 10, 180, 90);//绘制圆弧

g2.drawArc(179, 18, 10, 10, 270, 90);//绘制圆弧

g2.drawLine(5, 29, 185, 29);

}

else{

g2.setStroke(new BasicStroke(1.0f));

g2.setColor(normalc);

g2.drawLine(0, 0, 0, 25);

g2.drawLine(189, 0, 189, 25);

g2.drawLine(0, 0, 190, 0);

g2.drawArc(0, 18, 10, 10, 180, 90);//绘制圆弧

g2.drawArc(179, 18, 10, 10, 270, 90);//绘制圆弧

g2.drawLine(5, 29, 185, 29);

}

}

}

下面的代码就是主窗体了

Demo1:

import java.awt.Color;

import java.awt.event.MouseAdapter;

import java.awt.event.MouseEvent;

import javax.swing.ImageIcon;

import javax.swing.JButton;

import javax.swing.JFrame;

import javax.swing.JPasswordField;

import javax.swing.JTextField;

public class Demo1 {

public static void main(String[] args) {

//初始化窗体

JFrame frame=new JFrame("My QQ");

frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

frame.setSize(300, 200);

frame.setLocationRelativeTo(null);

frame.setLayout(null);

//添加账号面板

AccountPanel accountPanel=new AccountPanel(Color.LIGHT_GRAY,new Color(56,172,239));

accountPanel.setLayout(null);

accountPanel.setBounds(30, 15, 190, 30);

frame.add( accountPanel);

//在账号面板中添加文本框

JTextField accountTF=new JTextField();

accountTF.setBounds(7, 0, 153, 30);

accountTF.setOpaque(false);

accountTF.setBorder(null);

accountPanel.add(accountTF);

//在账号面板中的文本框后添加按钮

JButton jb1=new JButton(new ImageIcon(

Demo1.class.getClassLoader().getResource("res/images/btn1.png")));

jb1.setBounds(160, 0, 30, 30);

jb1.setBorder(null);//取消边框

jb1.setBorderPainted(false);//不绘制按钮边框

jb1.setContentAreaFilled(false);//设置按钮背景透明

jb1.setFocusPainted(false);//设置按钮不绘制焦点状态

accountPanel.add(jb1);

//密码面板

PasswordPanel passwordPanel=new PasswordPanel(Color.LIGHT_GRAY,new Color(56,172,239));

passwordPanel.setLayout(null);

passwordPanel.setBounds(30, 45, 190, 30);

frame.add( passwordPanel);

//输入密码文本框

JPasswordField passwordPF=new JPasswordField();

passwordPF.setBounds(7, 0, 153, 30);

passwordPF.setOpaque(false);

passwordPF.setBorder(null);

passwordPanel.add(passwordPF);

//在账号面板中的文本框后添加按钮

JButton jb2=new JButton(new ImageIcon(

Demo1.class.getClassLoader().getResource("res/images/btn2.png")));

jb2.setBounds(160, 0, 30, 30);

jb2.setBorder(null);

jb2.setBorderPainted(false);

jb2.setContentAreaFilled(false);

jb2.setFocusPainted(false);

passwordPanel.add(jb2);

//为账号输入框添加鼠标监听器

MouseAdapter accountListener=new MouseAdapter(){

@Override

public void mouseEntered(MouseEvent e) {

// TODO Auto-generated method stub

accountPanel.setBorder(true);

accountPanel.updateUI();

}

@Override

public void mouseExited(MouseEvent e) {

// TODO Auto-generated method stub

accountPanel.setBorder(false);

accountPanel.updateUI();

}

};

accountTF.addMouseListener(accountListener);

jb1.addMouseListener(accountListener);

//为密码输入框添加鼠标监听器

MouseAdapter passwordListener=new MouseAdapter(){

@Override

public void mouseEntered(MouseEvent e) {

// TODO Auto-generated method stub

passwordPanel.setBorder(true);

passwordPanel.updateUI();

}

@Override

public void mouseExited(MouseEvent e) {

// TODO Auto-generated method stub

passwordPanel.setBorder(false);

passwordPanel.updateUI();

}

};

passwordPF.addMouseListener(passwordListener);

jb2.addMouseListener(passwordListener);

frame.setVisible(true);

}

}

自此,仿QQ登录账号密码输入框就完成了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

java swing qq_java swing实现QQ账号密码输入框相关推荐

  1. java仿qq_java模仿实现QQ登录界面

    本文实例为大家分享了java模仿实现qq登录界面的具体代码,供大家参考,具体内容如下 这是我模仿QQ2015版界面,实现的基本功能有登陆验证,重置等,当然直接复制代码运行是不一样的,还要注意自己插入自 ...

  2. Java swing 仿QQ实现账号密码输入框

    Java swing 仿QQ之实现账号密码输入框 主要思路是自己定义 AccountPanel 和 PasswordPanel 类,继承JPanel,通过 paintComponent(Graphic ...

  3. Swing学习----------实现仿QQ注册功能

    在上一次的博客中实现了一个仿QQ的登录界面,现在将实现一个注册QQ账号的功能,在本文中将制作一个QQ注册的页面,然后通过一些swing中的组件来获取用户的信息,最后通过点击注册按钮将注册信息保存到My ...

  4. 基于java+mysql的Swing+MySQL图书管理系统(java+swing+gui+mysql)

    基于java+mysql的Swing+MySQL图书管理系统(java+swing+gui+mysql) 运行环境 Java≥8.MySQL≥5.7 开发工具 eclipse/idea/myeclip ...

  5. Java案例:Swing常用组件演示

    文章目录 一.Swing (一)Swing概述 (二)Swing与AWT的关系 (三)Swing组件继承关系图 二.Swing常用组件演示 (一)运行效果 (二)涉及知识点 (三)实现步骤 1.创建J ...

  6. JAVA图形编程Swing之——JPanel绘图

    JAVA图形编程Swing之--JPanel绘图     一直搞不清怎么在JPanel中绘2D图像,主要是不知怎样得到Graphics类的对像来画图,今天查了查资料,测试N种方法,终于搞明白.下面做一 ...

  7. java基础学习——Swing图形化用户界面编程

    GUI概述 早期计算机系统中,电脑向用户提供的是单调.枯燥.纯字符状态的"命令行界面(CLI)".就是到现在,我们还可以依稀看到它们的身影:在Windows中开个DOS窗口,就可看 ...

  8. Java中的Swing概述

    一.Swing特点 每个平台的GUI组件的显示会有所不同,但是在不同平台上运行使用Swing开发的应用程序时,就可以统一GUI组件的显示风格,因为Swing组件允许编程人员在跨平台时指定统一的外观和风 ...

  9. Java 中的 Swing 框架现在是不是被淘汰了?

    关于java中的Swing框架,我先说下如下的观点. 1 只要是用java开发的商业项目,就指着来挣钱的项目,都不会用Swing框架. 2 所以对java初学者来说,根本没必要学swing,甚至连类似 ...

最新文章

  1. 文件名有规则情况读取
  2. 日本京都大学 77TB重要数据被删;元宇宙要凉?Meta停止开发 VR/AR系统。 | 一周 IT 资讯...
  3. 230套java web开发PDF书籍和CHM参考手册资料大全 免费下载
  4. Asp.net支持三种类型的cache[转]
  5. TypeScript里一些特殊的类型
  6. 结合 AOP 轻松处理事件发布处理日志
  7. 气泡提示效果css.html,用纯CSS3绘制高端简约的气泡提示框
  8. 用汇编的眼光看C++(之class构造、析构)
  9. python case when用法_oracle菜鸟学习之 select case when的使用
  10. ceb怎么转换成word_关于把CEB文件转换成word文档!!!
  11. 高速公路坐标高程计算软件3.1版发布
  12. C# --- WinForm基本知识与绘图(上)
  13. 求指教,PSO算法跟踪光伏电池最大功率点
  14. 04L型匹配和T型匹配的核心算法
  15. Invalid interval string, expecting a number followed by one of Mwdhmsy
  16. UI设计,扁平化还是拟物化?
  17. C语言字母大小写转换
  18. 【地图学笔记】1 地图的基本知识
  19. nba购票系统php,2019nba中国赛门票怎么买?(附票价+购票方式)
  20. 二十岁的男人(你少哪些)

热门文章

  1. 兼容性问题及解决方案
  2. 如何在线上给证件打上水印
  3. 德国马牌轮胎助力中国国家男子足球队征战亚洲杯
  4. 怎样做好人生中的第一份工作?
  5. 国内的房地产ERP系统能够上线吗,实施效益如何
  6. 李玉婷MYSQL进阶03排序查询
  7. 未明学院学员报告:做了微博数据分析后,我发现现在最火的明星原来是……
  8. U盘误删文件如何找回来?
  9. SWIG入门文档(翻译自官方网站)
  10. 7天学会MVC——第1天