将图像插入 vaadin 网格
Insert image to vaadin grid
如何将图像(blob 类型)显示到 vaadin 网格中?
有什么好的例子吗?
如何为将保存 blob 的列定义正确的 class(我将我的图像存储为 blob mysql)在 vaadin 网格中键入图像?
如果用户没有图片,我还想在来自资源 ("/WEB-INF/images/user_pic.jpg") 的 vaadin 网格中显示默认图片 (user_pic.jpg)。
伪代码:
if (user have picture)
show his picture in grid
else
show default picture from resources
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.
这应该可以通过使用 ImageRenderer
shipped with Vaadin using a ThemeResource
轻松实现,但您可能需要将图像移动到主题目录下:webapp/VAADIN/themes/your_theme/images
2)
How to show images (blob type) into vaadin grid ?
据我所知,(还)没有内置渲染器可以满足您的需求,this question in the Vaadin forum. So far the ImageRenderer
sources 似乎证实了这一点,表明它仅支持 ExternalResource
或 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)");
}
您可能必须实现自己的渲染器。 Here and here 您可能会找到一个起点。顺便说一句,如果您决定编写您的实现,请考虑与世界其他地方分享它,我相信很多人会从中受益:-)
稍后编辑:
我刚刚想到一个 hack 可以与标准 ImageRenderer 一起使用。如果您可以存储编码为 base64 字符串的图像,那么您可以将它们包装在 ExternalResource 中,执行如下操作:
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"));
}
}
这应该会让你得到类似的东西:
我的问题的解决方案:
我使用了 table 而不是 网格 。这是我将图片嵌入 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);
我希望有人会发现此代码有用。如果您的图像(例如 blob)存储在数据库中,此代码是如何将图像插入 table 的很好示例。
如何将图像(blob 类型)显示到 vaadin 网格中?
有什么好的例子吗?
如何为将保存 blob 的列定义正确的 class(我将我的图像存储为 blob mysql)在 vaadin 网格中键入图像? 如果用户没有图片,我还想在来自资源 ("/WEB-INF/images/user_pic.jpg") 的 vaadin 网格中显示默认图片 (user_pic.jpg)。
伪代码:
if (user have picture)
show his picture in grid
else
show default picture from resources
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.
这应该可以通过使用 ImageRenderer
shipped with Vaadin using a ThemeResource
轻松实现,但您可能需要将图像移动到主题目录下:webapp/VAADIN/themes/your_theme/images
2)
How to show images (blob type) into vaadin grid ?
据我所知,(还)没有内置渲染器可以满足您的需求,this question in the Vaadin forum. So far the ImageRenderer
sources 似乎证实了这一点,表明它仅支持 ExternalResource
或 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)");
}
您可能必须实现自己的渲染器。 Here and here 您可能会找到一个起点。顺便说一句,如果您决定编写您的实现,请考虑与世界其他地方分享它,我相信很多人会从中受益:-)
稍后编辑:
我刚刚想到一个 hack 可以与标准 ImageRenderer 一起使用。如果您可以存储编码为 base64 字符串的图像,那么您可以将它们包装在 ExternalResource 中,执行如下操作:
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"));
}
}
这应该会让你得到类似的东西:
我的问题的解决方案:
我使用了 table 而不是 网格 。这是我将图片嵌入 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);
我希望有人会发现此代码有用。如果您的图像(例如 blob)存储在数据库中,此代码是如何将图像插入 table 的很好示例。