在JLabel上显示图片,并且图片自适应JLabel的大小
本文转载地址:
http://blog.csdn.net/xiaoliangmeiny/article/details/7060250
在写《Core Java》上的示例代码时,其中有一个FileChooserTest是打开一张图片,并在Label上显示出来,但是这个示例程序有缺点,由于窗口的大小已经固定,而选择打开的图片有大有小,如果图片比窗口大,则超过框口部分的则被隐藏没显示出来,要靠拖动窗口才能显示其余部分,若图片比较小,则打开在窗口中显得过小,于是稍作了修改。使得打开的图片可以完全根据窗口大小调整自身大小,也可以根据窗口的宽等比缩放。由于之前在网上搜索发现不少人遇到同样的问题,且大都没有有效解决掉,故把代码贴出来:
- package FileChooserTest;
- import java.awt.BorderLayout;
- import java.awt.Dimension;
- import java.awt.EventQueue;
- import java.awt.Image;
- import java.awt.event.ActionEvent;
- import java.awt.event.ActionListener;
- import java.beans.PropertyChangeEvent;
- import java.beans.PropertyChangeListener;
- import java.io.File;
- import javax.swing.BorderFactory;
- import javax.swing.Icon;
- import javax.swing.ImageIcon;
- import javax.swing.JFileChooser;
- import javax.swing.JFrame;
- import javax.swing.JLabel;
- import javax.swing.JMenu;
- import javax.swing.JMenuBar;
- import javax.swing.JMenuItem;
- import javax.swing.SwingConstants;
- import javax.swing.UIManager;
- import javax.swing.UnsupportedLookAndFeelException;
- import javax.swing.filechooser.FileFilter;
- import javax.swing.filechooser.FileNameExtensionFilter;
- import javax.swing.filechooser.FileView;
- public class FileChooserTest {
- public static void main(String[] args) {
- EventQueue.invokeLater(new Runnable() {
- public void run() {
- ImageViewerFrame frame = new ImageViewerFrame();
- frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
- frame.setVisible(true);
- }
- });
- }
- }
- class ImageViewerFrame extends JFrame {
- public ImageViewerFrame() {
- super("ImageViewer");
- setSize(WIDTH, HEIGHT);
- try {
- UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
- } catch (Exception e) {
- //
- }
- JMenuBar menuBar = new JMenuBar();
- setJMenuBar(menuBar);
- JMenu menu = new JMenu("File");
- JMenuItem openItem = new JMenuItem("open");
- menu.add(openItem);
- openItem.addActionListener(new FileOpenListener());
- JMenuItem exitItem = new JMenuItem("exit");
- menu.add(exitItem);
- menuBar.add(menu);
- exitItem.addActionListener(new ActionListener() {
- public void actionPerformed(ActionEvent e) {
- // TODO Auto-generated method stub
- System.exit(0);
- }
- });
- //use a label to display a image
- label =new JLabel();
- add(label,BorderLayout.CENTER);
- chooser=new JFileChooser();
- FileNameExtensionFilter filter =new FileNameExtensionFilter("Image Files", "jpg","jpeg","gif");
- chooser.setFileFilter(filter);
- //预览
- chooser.setAccessory(new ImagePreviewer(chooser));
- //accessory 通常用于显示已选中文件的预览图像
- // chooser.setFileView(new FileIconView(filter,new ImageIcon("palette.gif")));
- chooser.setFileView(new FileIconView(filter, new ImageIcon()));
- //设置用于检索 UI 信息的文件视图,如表示文件的图标或文件的类型描述。
- }
- private class FileOpenListener implements ActionListener{
- @Override
- public void actionPerformed(ActionEvent e) {
- // TODO Auto-generated method stub
- chooser.setCurrentDirectory(new File("."));
- int result=chooser.showOpenDialog(ImageViewerFrame.this);
- if(result==JFileChooser.APPROVE_OPTION){
- String name=chooser.getSelectedFile().getPath();
- ImageIcon icon=new ImageIcon(name);
- // 等比缩放条件
- // int imgWidth=icon.getIconWidth();
- // int imgHeight=icon.getIconHeight();
- // int conWidth=getWidth();
- // int conHeight=getHeight();
- // int reImgWidth;
- // int reImgHeight;
- // if(imgWidth/imgHeight>=conWidth/conHeight){
- // if(imgWidth>conWidth){
- // reImgWidth=conWidth;
- // reImgHeight=imgHeight*reImgWidth/imgWidth;
- // }else{
- // reImgWidth=imgWidth;
- // reImgHeight=imgHeight;
- // }
- // }else{
- // if(imgWidth>conWidth){
- // reImgHeight=conHeight;
- // reImgWidth=imgWidth*reImgHeight/imgHeight;
- // }else{
- // reImgWidth=imgWidth;
- // reImgHeight=imgHeight;
- // }
- // }
- //这个是强制缩放到与组件(Label)大小相同
- icon=new ImageIcon(icon.getImage().getScaledInstance(getWidth(), getHeight()-25, Image.SCALE_DEFAULT));
- //这个是按等比缩放
- // icon=new ImageIcon(icon.getImage().getScaledInstance(reImgWidth, reImgHeight, Image.SCALE_DEFAULT));
- label.setIcon(icon);
- label.setHorizontalAlignment(SwingConstants.CENTER);
- }
- }
- }
- public static final int WIDTH = 500;
- public static final int HEIGHT = 500;
- private JLabel label;
- private JFileChooser chooser;
- }
- class FileIconView extends FileView {
- public FileIconView(FileFilter aFilter,Icon anIcon){
- filter=aFilter;
- icon=anIcon;
- }
- public Icon getIcon(File f){
- if(!f.isDirectory()&&filter.accept(f)){
- return icon;
- }else return null;
- }
- private FileFilter filter;
- private Icon icon;
- }
- class ImagePreviewer extends JLabel{
- public ImagePreviewer(JFileChooser chooser){
- setPreferredSize(new Dimension(100,100));
- setBorder(BorderFactory.createEtchedBorder());
- chooser.addPropertyChangeListener(new PropertyChangeListener() {
- public void propertyChange(PropertyChangeEvent event) {
- if(event.getPropertyName()==JFileChooser.SELECTED_FILE_CHANGED_PROPERTY){
- File f=(File) event.getNewValue();
- if(f==null){
- setIcon(null);
- return;
- }
- ImageIcon icon=new ImageIcon(f.getPath());
- // if(icon.getIconWidth()>getWidth()){
- icon=new ImageIcon(icon.getImage().getScaledInstance(getWidth(), -1, Image.SCALE_DEFAULT));
- // }
- setIcon(icon);
- }
- }
- });
- }
- }
选择等比缩放还是完全自适应,看代码注释处切换。
在JLabel上显示图片,并且图片自适应JLabel的大小的更多相关文章
- MFC上显示摄像头JPEG图片数据的两种方法
其一是借助opencv,其二是利用流对象. 方法一: CvMat *mat; ,,CV_8UC1); ,,CV_8UC1,JPEGBuf); /*初始化矩阵信息头,这里的JPEGBuf就是JPEG图像 ...
- 多媒体开发(4):在视频上显示文字或图片--ffmpeg命令
小白:我录了段视频,里面用的音乐是有版权的,而且快过期了,能把音乐去掉吗? 小程拿到视频后,一个快捷键打开命令终端,快速打下一行命令: ffmpeg -i 小白.flv -vcodec copy -a ...
- iOS 上传的图片在HTML上显示时,图片方向信息(EXIF Orientation)异常
将iPhone 6s拍摄的照片上传到服务器之后, 在Web网页上看到图片被逆时针旋转了90度, 这让我很惆怅呐! 出现这个问题其实是因为上传的图片为.jpg格式,.jpg文件含有EXIF信息, 其中E ...
- Python3 tkinter基础 Label compound 图片上显示文字 fg字体颜色 font字体大小
Python : 3.7.0 OS : Ubuntu 18.04.1 LTS IDE : PyCharm 2018.2.4 Conda ...
- 【小梅哥FPGA进阶教程】串口发送图片数据到SRAM在TFT屏上显示
十五.串口发送图片数据到SRAM在TFT屏上显示 之前分享过rom存储图片数据在TFT屏上显示,该方法只能显示小点的图片,如果想显示TFT屏幕大小的图片上述方法rom内存大小不够.小梅哥给了个方案,利 ...
- MySQL数据库写入图片并读取图片显示到JLabel上的详解
相较于Oracle,MySQL作为一个轻量级的开源的数据库,可谓是大大简化了我们的操作.这次我就来写一个关于数据库存入图片,获取图片的例子吧,也为了今后的复习使用.(我们一般采取存入路径的方式,而不是 ...
- html小知识点汇总(浏览器导航上显示图标、div无高度时试着清除浮动、文字环绕图片、字体加粗、div按百分比分、已有的不合适的class,针对特定的标签进行修改)
1.新点击的网页,在浏览器导航上显示图标: 像这种效果: <head> <meta charset="UTF-8"> <meta name=" ...
- html5 图片上传,支持图片预览、压缩、及进度显示,兼容IE6+及标准浏览器
以前写过上传组件,见 打造 html5 文件上传组件,实现进度显示及拖拽上传,兼容IE6+及其它标准浏览器,对付一般的上传没有问题,不过如果是上传图片,且需要预览的话,就力有不逮了,趁着闲暇时间,给上 ...
- javascript DOM(2) 一个网页上切换显示不同的图片或文本
摘自: javascript DOM 编程艺术 1. 在一个网页上切换显示不同的图片 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Tran ...
随机推荐
- 【转】JS判断SWF,JPG加载完毕、兼容(Activex,plugIn)所有浏览器
JS判断SWF,JPG加载完毕.兼容(Activex,plugIn)所有浏览器 这里主要说下监听SWF的加载. 网上流传已久的监听方法,只能在IE(Activex插件下)下实现.在使用plugin的浏 ...
- Html5 Canvas笔记(1)-CanvasAppTemplate代码
学了一段时间的Html5 Canvas,现想一段一段的将学习笔记整理出来放上来,先整理一段Canvas的模版文件代码,以后建立Canvas程序就不用重新写这些代码了,当然最好是将这个Html代码保存到 ...
- 【HTML5】选项卡
效果图: HTML: <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> ...
- position relative
position的默认值是static,(也就是说对于任意一个元素,如果没有定义它的position属性,那么它的position:static) 如果你想让这个#demo里的一个div#sub相对于 ...
- memory库函数的实现
下面主要对常用的几个memory库函数的实现(memcpy.memmove.memset.memcmp): memcpy函数与memmove函数: 相同点: 两者实现的功能均为从src拷贝count个 ...
- 容器 What, Why, How - 每天5分钟玩转容器技术(6)
学习任何东西都可以按照3W的框架进行,容器技术也是一样,先回答 What.Why 和 How 这三个问题. What - 什么是容器? 容器是一种轻量级.可移植.自包含的软件打包技术,使应用程序可以在 ...
- StringHelper--封转自己的字符串工具类
我们每次开发项目,都会有很多的关于字符串的处理,字符串的处理太常见了,无法避免,那么这时如果可以把常用的字符串处理封装成类,在以后的开发中应该会减少一些工作量,下面代码对一些常用的字符串处理进行了封装 ...
- 使用RandomAccessFile在两个java进程之间传递数据
大部分情况下,我们面对在两个java进程只见传递数据的问题时,第一个想到的就是开server,然后通过socket收发消息.这方面有大量的框架可用,就不细说了.但如果两个进程是在一台机器上,那么还可以 ...
- SQLiteServer+SQLiteClient 用于.Net项目的SQLite服务端程序和客户端类库
SQLite没有官方的支持CS方式调用的方式,因项目需要我自行开发了一个简易的版本. 当前版本支持的方法 SQLiteOpen(fileName):bool SQLiteClose():void SQ ...
- 关于特殊文件权限:suid、sgid和sticky-bit
用 ls –l 命令时,能看到三个八进制数字,表示文件的权限.其实文件的权限应该用4个八进制文件来表示,没有显示的那个是第一位,用来设定一些特殊的权限,这个八进制数字的三个位是:SUID.SGID.s ...