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:
