我定义了一个存储过程将图片文件存在了数据库表的image字段,现在想用VC把它显示视图上,该怎么实现?谢谢各位高手指点。

解决方案 »

  1.   

    这是GDI的问题,如果你会把图形文件显示出来,就应该可以把从数据库中取回的数据显示出来
    流程都应该是:用数据创建图形对象,然后在设定的区域显示
    创建图形对象的办法可以借用开源代码,也可以使用微软的IPicture接口
      

  2.   

    http://www.pcvc.net/category/content.asp?sendid=189
      

  3.   

    http://www.pcvc.net/category/content.asp?sendid=189
    的帖子我看了,但有些地方不太明白(我是初学),从代码看,工程名字应该是Image,那么应该是CImageSet::CdbImageSet(CDatabase* pdb),为什么是CdbImages::CdbImages(CDatabase* pdb);难道是新建的第二个CRecordset对象,应该怎样把这些代码组织到自己的工程中去了?哪位能不能帮忙解释一下,万分感谢。
      

  4.   

    用二进制数据读出后,构造bitmap,不过只能显示bmp文件,其它格式的我也不会了。
    http://www.vckbase.com/document/viewdoc/?id=674
    读出二进制数据时,注意只用位图数据部分构造bitmap,别把这个二进制数据都送去构造bitmap了
      

  5.   

    是这么存的,jpg格式:CREATE PROCEDURE sp_textcopy ( 
      @srvname    varchar (30), 
      @login      varchar (30), 
      @password    varchar (30), 
      @dbname      varchar (30), 
      @tbname      varchar (30), 
      @colname    varchar (30), 
      @filename    varchar (30), 
      @whereclause varchar (40), 
      @direction  char(1)) 
    AS 
    DECLARE @exec_str varchar (255) 
    SELECT @exec_str = 
            'textcopy /S ' + @srvname + 
            ' /U ' + @login + 
            ' /P ' + @password + 
            ' /D ' + @dbname + 
            ' /T ' + @tbname + 
            ' /C ' + @colname + 
            ' /W "' + @whereclause + 
            '" /F ' + @filename + 
            ' /' + @direction 
    EXEC master..xp_cmdshell @exec_strGOsp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\图片.jpg','where 编号=1','I' --注意条件是 编号=1