0

How to show images (blob type) into vaadin grid ?

Is there any good example ?

How to define right class for coloumns that will hold blob (i store my images as blob in mysql) type image in vaadin grid ? I also want to show default picture (user_pic.jpg) in vaadin grid from resources ("/WEB-INF/images/user_pic.jpg") if user doesn't have picture.

PSEUDO CODE:

if (user have picture)
  show his picture in grid
else 
 show default picture from resources
slodeveloper
  • 225
  • 3
  • 21
  • If you saw the previous version of my answer, take a look at the updated one. I figured a _hack_ which should allow you to use the current ImageRenderer with ExternalResource **if** you can [save your images as base64 strings](http://stackoverflow.com/questions/9722603/storing-image-in-database-directly-or-as-base64-data) at the cost of some bandwith & maybe load time, depending on your usage. – Morfic Mar 11 '16 at 23:48

2 Answers2

1

SOLUTION TO MY PROBLEM:

I used table instead grid. Here is my code for emdadding pictures into table:

        Person tr = tap.get(i);

        Embedded emb=new Embedded("myembeddedimage");

        StreamResource.StreamSource source = new StreamResource.StreamSource() {

            public InputStream getStream() {
                 //get blob inputstream
                 return new ByteArrayInputStream(tr.getPicture());
            }

         };
       //create StreamResource from blob inputstream and name it.
       StreamResource sourceone=new StreamResource(source, "mypicture.png");
       sourceone.setCacheTime(0l); 
       emb.setHeight("200px");
       emb.setWidth("150px");
       //if user doesn't have image, the embedded image source is set to image from resource
       emb.setSource(tr.getPicture()==null? new ThemeResource("images/user_pic.jpg"): sourceone);

       CheckBox checkbox=new CheckBox();
        checkbox.setConvertedValue(false);

       tPartners.addItem((new Object[] {emb,
                (tr.getName() +" "+ tr.getSurname()), -2,checkbox}),tr);

I hope someone will find this code useful. This code is good example how to insert image into table if you have your image (as blob for example) stored in database.

slodeveloper
  • 225
  • 3
  • 21
0

1)

I also want to show default picture (user_pic.jpg) in vaadin grid from resources ("/WEB-INF/images/user_pic.jpg") if user doesn't have picture.

This should be easily doable by using the ImageRenderer shipped with Vaadin using a ThemeResource, but you may need to move your image under your theme directory instead: webapp/VAADIN/themes/your_theme/images


2)

How to show images (blob type) into vaadin grid ?

As far as I know there isn't (yet) a built-in renderer that can do what you need, which seems to be confirmed by this question in the Vaadin forum. So far the ImageRenderer sources indicate that it only supports either ExternalResource or ThemeResource:

@Override
    public JsonValue encode(Resource resource) {
        if (!(resource == null || resource instanceof ExternalResource || resource instanceof ThemeResource)) {
            throw new IllegalArgumentException(
                    "ImageRenderer only supports ExternalResource and ThemeResource ("
                            + resource.getClass().getSimpleName() + " given)");
        }

You will probably have to implement your own renderer. Here and here you might find a starting point. And btw, if you do decide to write your implementation, please consider sharing it with the rest of the world, I'm sure a lot of people would benefit from it :-)


Later edit:

I just thought of a hack you can use with the standard ImageRenderer. If you can store your images encoded as base64 strings then you can wrap them in a ExternalResource doing something like this:

public static class MyBean {
    private ExternalResource image;
    private String name, surname;

    public MyBean(ExternalResource image, String name, String surname) {
        this.image = image;
        this.name = name;
        this.surname = surname;
    }

    public ExternalResource getImage() {
        return image;
    }

    public String getName() {
        return name;
    }

    public String getSurname() {
        return surname;
    }
}
public class MyGridComponent extends VerticalLayout {
    public MyGridComponent() {
        BeanItemContainer<MyBean> dataSource = new BeanItemContainer<>(MyBean.class);
        Grid grid = new Grid(dataSource);
        addComponent(grid);


        grid.getColumn("image").setRenderer(new ImageRenderer());
        grid.setColumnOrder("image", "name", "surname");

        dataSource.addItem(new MyBean(
                new ExternalResource(""),
                "Agent",
                "Smith"));
        dataSource.addItem(new MyBean(
                new ExternalResource(""),
                "There is",
                "No spoon"));
        dataSource.addItem(new MyBean(
                new ExternalResource(""),
                "The",
                "One"));
    }
}

Which should get you something similar to:

Demo

Community
  • 1
  • 1
Morfic
  • 14,178
  • 3
  • 40
  • 55