当时,我通过网络摄像头捕获库成功操作了我的网络摄像头。 这是我的代码:
public void capture() {
wc.setViewSize(WebcamResolution.QVGA.getSize());
WebcamPanel wp = new WebcamPanel(wc);
wp.setMirrored(true);
JPanel jp = new JPanel();
tp.setSize(jp.getWidth(), jp.getHeight());
tp.addTab("", wp);
tp.getParent().revalidate();
}
我想将捕获图像保存到我的数据库(mysql)中, 好事是我能够成功保存它。 使用此代码:
public void save() {
BufferedImage bi = wc.getImage();
try {
ByteArrayOutputStream bimg = new ByteArrayOutputStream();
ImageIO.write(bi, "JPG", bimg);
byte[] imgb = bimg.toByteArray();
try {
Blob bis = conn.createBlob();
bis.setBytes(1, imgb);
String query = "insert into tbl_img (imgid,clientimg) values ('" + but.getText() + "' , '" + bis + "')";
psmt = conn.prepareStatement(query);
psmt.executeUpdate();
JOptionPane.showMessageDialog(null, "Success", "Capture", JOptionPane.NO_OPTION);
} catch (Exception e) {
e.printStackTrace();
}
} catch (IOException e) {
JOptionPane.showMessageDialog(null, e);
}
}
从BufferedImage我转换它ByteArray以适应mysql Blob标志。 与插入数据相反,我希望将其作为图像检索回来并直接通过JFrame将其放入JLabel中。我们可以说不占用硬盘中的一些空间。
我有一个用于检索图片的代码,但结果似乎只是一个白色的JFrame。
public void open() {
try {
stmt = conn.createStatement();
String quer = " select clientimg from tbl_img where imgid='" + open.getText() + "' ";
ResultSet rs = stmt.executeQuery(quer);
while (rs.next()) {
byte[] inbytes = rs.getBytes("clientimg");
Image img = Toolkit.getDefaultToolkit().createImage(inbytes);
ImageIcon ico = new ImageIcon(img);
JFrame jf = new JFrame("Viewer");
JLabel jl = new JLabel();
jl.setSize(ico.getIconWidth(), ico.getIconHeight());
jf.setSize(ico.getIconWidth(), ico.getIconHeight());
jl.setIcon(ico);
jf.add(jl);
jf.setVisible(true);
}
} catch (Exception e) {
e.printStackTrace();
}
}
是否有其他方法或将blob检索回图像?如果有可以随意修改代码让我更清楚地理解。我试过了,我认为谷歌可以采取一切可能的方式。