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 
1
  • 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 at the cost of some bandwith & maybe load time, depending on your usage. Commented Mar 11, 2016 at 23:48

2 Answers 2

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.

Sign up to request clarification or add additional context in comments.

Comments

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

Comments

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.