BF [2983759] - improve the image viewer in swing client
https://sourceforge.net/tracker/index.php?func=detail&aid=2983759&group_id=176962&atid=883808
This commit is contained in:
parent
deaa6cf731
commit
250cddc8ea
|
@ -17,11 +17,13 @@
|
|||
package org.compiere.grid.ed;
|
||||
|
||||
import java.awt.Color;
|
||||
import java.awt.Image;
|
||||
import java.awt.event.ActionEvent;
|
||||
import java.awt.event.ActionListener;
|
||||
import java.beans.PropertyChangeEvent;
|
||||
import java.beans.PropertyVetoException;
|
||||
|
||||
import javax.swing.ImageIcon;
|
||||
import javax.swing.JButton;
|
||||
|
||||
import org.compiere.model.MImage;
|
||||
|
@ -80,6 +82,8 @@ public class VImage extends JButton
|
|||
*/
|
||||
public void setValue(Object value)
|
||||
{
|
||||
final int COLUMNSIZE = 220;
|
||||
|
||||
int newValue = 0;
|
||||
if (value instanceof Integer)
|
||||
newValue = ((Integer)value).intValue();
|
||||
|
@ -97,7 +101,21 @@ public class VImage extends JButton
|
|||
//
|
||||
log.fine(m_mImage.toString());
|
||||
super.setText(null);
|
||||
|
||||
if (m_mImage.getImage()==null)
|
||||
return;
|
||||
|
||||
ImageIcon image = new ImageIcon(m_mImage.getImage());
|
||||
if (image.getIconHeight() > COLUMNSIZE || image.getIconWidth() > COLUMNSIZE) {
|
||||
if (image.getIconHeight() > image.getIconWidth()) {
|
||||
super.setIcon(new ImageIcon(m_mImage.getImage().getScaledInstance(-1, COLUMNSIZE, Image.SCALE_DEFAULT)));
|
||||
} else {
|
||||
super.setIcon(new ImageIcon(m_mImage.getImage().getScaledInstance(COLUMNSIZE, -1, Image.SCALE_DEFAULT)));
|
||||
}
|
||||
} else {
|
||||
// the image is smaller than the COLUMNSIZE
|
||||
super.setIcon(m_mImage.getIcon());
|
||||
}
|
||||
super.setToolTipText(m_mImage.getName());
|
||||
invalidate();
|
||||
} // setValue
|
||||
|
|
|
@ -20,8 +20,11 @@ import java.awt.BorderLayout;
|
|||
import java.awt.Color;
|
||||
import java.awt.Cursor;
|
||||
import java.awt.Frame;
|
||||
import java.awt.Image;
|
||||
import java.awt.event.ActionEvent;
|
||||
import java.awt.event.ActionListener;
|
||||
import java.awt.event.ComponentEvent;
|
||||
import java.awt.event.ComponentListener;
|
||||
import java.io.ByteArrayOutputStream;
|
||||
import java.io.File;
|
||||
import java.io.FileInputStream;
|
||||
|
@ -30,6 +33,7 @@ import java.util.logging.Level;
|
|||
import javax.swing.BorderFactory;
|
||||
import javax.swing.ImageIcon;
|
||||
import javax.swing.JFileChooser;
|
||||
import javax.swing.JLabel;
|
||||
import javax.swing.SwingConstants;
|
||||
|
||||
import org.compiere.apps.AEnv;
|
||||
|
@ -80,6 +84,46 @@ public class VImageDialog extends CDialog
|
|||
m_mImage = MImage.get (Env.getCtx(), 0);
|
||||
fileButton.setText(m_mImage.getName());
|
||||
imageLabel.setIcon(m_mImage.getIcon());
|
||||
imageLabel.addComponentListener(new ComponentListener() {
|
||||
|
||||
@Override
|
||||
public void componentHidden(ComponentEvent e) {}
|
||||
|
||||
@Override
|
||||
public void componentMoved(ComponentEvent e) {}
|
||||
|
||||
@Override
|
||||
public void componentResized(ComponentEvent e) {
|
||||
Image image = m_mImage.getImage();
|
||||
JLabel label = (JLabel) e.getComponent();
|
||||
|
||||
System.err.println("iamge:" + image + " M_mImage: " + m_mImage);
|
||||
|
||||
if (image == null)
|
||||
return;
|
||||
|
||||
int imageheight = image.getWidth(null);
|
||||
int imagewidth = image.getWidth(null);
|
||||
int labelheight = label.getHeight();
|
||||
int labelwidth = label.getWidth();
|
||||
|
||||
if (labelheight == 0 || imageheight == 0)
|
||||
return;
|
||||
|
||||
// check which dimension we have to scale
|
||||
if ((double) labelwidth / labelheight < (double) imagewidth / imageheight) {
|
||||
// do not upscale images
|
||||
if (imagewidth > labelwidth)
|
||||
label.setIcon(new ImageIcon(m_mImage.getImage().getScaledInstance(label.getWidth(), -1, Image.SCALE_DEFAULT)));
|
||||
} else {
|
||||
if (imageheight > labelheight)
|
||||
label.setIcon(new ImageIcon(m_mImage.getImage().getScaledInstance(-1, label.getHeight(), Image.SCALE_DEFAULT)));
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void componentShown(ComponentEvent e) {}
|
||||
});
|
||||
AEnv.positionCenterWindow(owner, this);
|
||||
} // VImageDialog
|
||||
|
||||
|
|
Loading…
Reference in New Issue