在Qt中如何加载图像以及保存图像到数据库中

来源:互联网 发布:如何开通淘宝直播间 编辑:程序博客网 时间:2024/05/17 08:12
在Qt中如何加载图像以及保存图像到数据库中
先前写过一个在PHP中往数据库中保存图像以及如何读取显示出来:
http://www.qtcn.org/blog/blog.php?do-showone-itemid-479-type-blog.html
现在遇到了在Qt中把图像保存到数据库中(以BLOB类型保存)的问题,这里总结一下,供各位朋友参考
基本的思想和前面的使用PHP保存头像是一样的,这里以例子解说
1、加载一个头像到界面上显示出来(labelZhaoPian的大小是80x96)
     显示头像,这里用QLabel来显示,代码如下:
    extern QString g_strCurrentDir;
    QString strImage = QFileDialog::getOpenFileName(this, "请选择照片文件", g_strCurrentDir, "图像文件 (*.png *.jpg *.bmp *.gif)");
    if (strImage.isNull())
    {
        return;
    }
    g_strCurrentDir = QDir(strImage).absolutePath();
    labelZhaoPian->setPixmap(QPixmap(strImage).scaled(labelZhaoPian->size()));
相应地,清除头像的代码就很简单了
        labelZhaoPian->setPixmap(QPixmap());
    labelZhaoPian->setText("照\n\n片");
2、保存图像到数据库中,以PNG格式
    if (labelZhaoPian->pixmap()->isNull() == false)
    {
        QByteArray bytes;
        QBuffer buffer(&bytes);
        buffer.open(QIODevice::WriteOnly);
        labelZhaoPian->pixmap()->save(&buffer, "PNG");
                QString out;
            for(int n = 0; n 
3、从数据库中读取出图像来,并显示
        QSqlQuery q("SELECT photo FROM profile WHERE iprofileid = 1");
         if (q.next())
         {
            if (q.isNull(0) == false)
        {
            QPixmap photo;
            photo.loadFromData(q.value(0).toByteArray(), "PNG");
            labelZhaoPian->setPixmap(photo);
        }
         }