RCP编程技巧:如何显示Mysql数据库中存储的图片?

我在程序开发中,经常要将图片文件存入Mysql数据库的longblob字段中,存入数据库和以前在jsp中没什么区别,那么,如何将存入数据库的图片在SWT中显示呢?


首先,我写了一个方法,将inputstream取出,
public InputStream getImage(String id) {


DataConfig config = new DataConfig();
InputStream stream = null;


try {


config.openConnection();
Connection conn = config.getConnection();
PreparedStatement pStmt = conn
.prepareStatement("select bugimage from bugs where id=?");
pStmt.setString(1, id);
ResultSet rs = pStmt.executeQuery();
if (rs != null) {
while (rs.next()) {
stream = rs.getBinaryStream(1);
}
rs.close();
}
pStmt.close();
} catch (SQLException e) {


e.printStackTrace();
}


return stream;


}


然后,在程序中使用SWT的Image类和Canvas类将图片显示出来,代码如下:


//其中Canvas显示滚动条的代码来自eclipse网站
Composite composite = new Composite(parent, SWT.NONE);
GridLayout gridLayout = new GridLayout(1, false);
gridLayout.marginWidth = 10;
gridLayout.marginHeight = 10;
gridLayout.horizontalSpacing = 10;
gridLayout.verticalSpacing = 10;
composite.setLayout(gridLayout);
GridData gridData = new GridData(GridData.FILL, GridData.CENTER, false,
false);
composite.setLayoutData(gridData);


image = new Image(Display.getDefault(), getImage("1"));

if (image == null) {
int width = 150, height = 200;
image = new Image(FireiceUtil.getDisplay(), width, height);
GC gc = new GC(image);
gc.fillRectangle(0, 0, width, height);
gc.drawLine(0, 0, width, height);
gc.drawLine(0, height, width, 0);
gc.drawText("No Image", 10, 10);
gc.dispose();
}


canvas = new Canvas(composite, SWT.NO_BACKGROUND | SWT.NO_REDRAW_RESIZE
| SWT.V_SCROLL | SWT.H_SCROLL);
GridData canvasGridData = new GridData();
canvasGridData.heightHint = 400;
canvasGridData.widthHint = 500;
canvas.setLayoutData(canvasGridData);


final Point origin = new Point(0, 0);
final ScrollBar hBar = canvas.getHorizontalBar();
hBar.addListener(SWT.Selection, new Listener() {
public void handleEvent(Event e) {
int hSelection = hBar.getSelection();
int destX = -hSelection - origin.x;
Rectangle rect = image.getBounds();
canvas.scroll(destX, 0, 0, 0, rect.width, rect.height, false);
origin.x = -hSelection;
}
});
final ScrollBar vBar = canvas.getVerticalBar();
vBar.addListener(SWT.Selection, new Listener() {
public void handleEvent(Event e) {
int vSelection = vBar.getSelection();
int destY = -vSelection - origin.y;
Rectangle rect = image.getBounds();
canvas.scroll(0, destY, 0, 0, rect.width, rect.height, false);
origin.y = -vSelection;
}
});
canvas.addListener(SWT.Resize, new Listener() {
public void handleEvent(Event e) {
Rectangle rect = image.getBounds();
Rectangle client = canvas.getClientArea();
hBar.setMaximum(rect.width);
vBar.setMaximum(rect.height);
hBar.setThumb(Math.min(rect.width, client.width));
vBar.setThumb(Math.min(rect.height, client.height));
int hPage = rect.width - client.width;
int vPage = rect.height - client.height;
int hSelection = hBar.getSelection();
int vSelection = vBar.getSelection();
if (hSelection >= hPage) {
if (hPage <= 0)
hSelection = 0;
origin.x = -hSelection;
}
if (vSelection >= vPage) {
if (vPage <= 0)
vSelection = 0;
origin.y = -vSelection;
}
canvas.redraw();
}
});
canvas.addListener(SWT.Paint, new Listener() {
public void handleEvent(Event e) {
GC gc = e.gc;
gc.drawImage(image, origin.x, origin.y);
Rectangle rect = image.getBounds();
Rectangle client = canvas.getClientArea();
int marginWidth = client.width - rect.width;
if (marginWidth > 0) {
gc.fillRectangle(rect.width, 0, marginWidth, client.height);
}
int marginHeight = client.height - rect.height;
if (marginHeight > 0) {
gc
.fillRectangle(0, rect.height, client.width,
marginHeight);
}
}
});



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值