简体   繁体   中英

Java jTable adding html img tag with base64 image

New to Java and this JTable. I am wanting to add an image to one of the cells in a column. I am able to add the image but its not displaying the image, just an image of a broken image link:

在此处输入图片说明

This is the code I am using in order to populate those images:

 @SuppressWarnings("unused") public void createAvatar(String b64image, String name, int row, int col) { String html = String.format("<html><table><td><img alt=\\"Avatar\\" style=\\"position: absolute; top: 0px; left: 0px;\\" src=\\"data:image/png;base64,%s\\"/>%s</td></table></html>", b64image, name); table.setValueAt(html, row, col); } 
private void initialize() throws Exception {
...MORE CODE HERE...
try {
    for (int i = 0; i < b64s.size(); i++) {
       createAvatar(b64s.get(i), names.get(i), i, 8);
    }
} catch(Exception e) {
    JOptionPane.showMessageDialog(null, e);
}

table = new JTable(model) {
   @Override
   public boolean isCellEditable (int row, int col)
   {
        return true;
   }

   public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int col) {
        return null;
   }

   public Component prepareRenderer(TableCellRenderer renderer, int row, int column) {
        Component c = super.prepareRenderer(renderer, row, column);

        if (c instanceof JComponent) {
             if(column == 4){
                JComponent jc = (JComponent) c;
                jc.setToolTipText(getValueAt(row, column).toString());
             }
        }

        return c;
   }
};

table.getModel().addTableModelListener(new TableModelListener() {
   @SuppressWarnings("static-access")
   public void tableChanged(TableModelEvent e) {
   ...MORE CODE HERE...
});

table.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);

for (int i = 0; i < b64s.size(); i++) {
   createAvatar(b64s.get(i), names.get(i), i, 8);
}
}

If I use a hard coded drive path like this:

@SuppressWarnings("unused")
public void createAvatar(String b64image, String name, int row, int col) {      
     String html = String.format("<html><table><td><img alt=\"Avatar\" style=\"position: absolute; top: 0px; left: 0px;\" src=\"%s\"/>%s</td></table></html>", "file:///C:/Users/xxxxxx/eclipse-workspacePhoton_xxxxx/xxxxx/resources/avatarB.png", name);
     table.setValueAt(html, row, col);
}

It works just fine:

在此处输入图片说明

And when I do the same thing but with a hard coded base64 string:

String html = String.format("<html><table><td><img alt=\"Avatar\" style=\"position: absolute; top: 0px; left: 0px;\" src=\"data:image/png;base64,%s\"/>%s</td></table></html>", "....aZ9htT6WuJRFzV3epJcukNncYXzbPKIUjXzcWmUe+K7lQ3q/tn0/Gbk89e3sSussuZpu2D1Wj0P0mjaW2u8Si/mHPSBJpmUUM8x9EVbrT4j3P9QAAAABJRU5ErkJggg==", name);

It displays the same as non-hard coded string:

在此处输入图片说明

And copying the HTML variable from the code:

<html><table><td><img alt="Avatar" style="position: absolute; top: 0px; left: 0px;" src=".....ussuZpu2D1Wj0P0mjaW2u8Si/mHPSBJpmUUM8x9EVbrT4j3P9QAAAABJRU5ErkJggg=="/>Bob</td></table></html>

 <html><table><td><img alt="Avatar" style="position: absolute; top: 0px; left: 0px;" src=""/>Bob</td></table></html> 

Does display just fine (meaning the base64 image is correct and working)

So can I not use the Base64 version inside the HTML for the jTable?

Instead of using html you could try to use swing components directly. From your question it looks like you have a column that represents a user avatar so let's say the data is of type Avatar .

Then you could set a custom cell renderer for that column type and have that renderer return a JLabel . That label can take a text as well as an icon, so the code could look like this (simplified):

JTable table = ...;

table.setDefaultRenderer( Avatar.class, new TableCellRenderer() {      
  @Override
  public Component getTableCellRendererComponent( JTable table, Object value, boolean isSelected, 
                                 boolean hasFocus, int row, int column )
  {
    Avatar avatar = (Avatar)value;

    //you might want to think about caching the icon and maybe even the label.
    Icon icon = new ImageIcon(Base64.decode( avatar.getBase64Image() ));
    return new JLabel(avatar.getName(), icon, JLabel.LEFT);
  }
} );

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM