动态保存CxGrid图像列:Jpg图片与Clipboard操作源码

需积分: 17 19 下载量 6 浏览量 更新于2024-09-10 收藏 2KB TXT 举报
本文档主要介绍了如何在CxGrid(一个常用的Delphi网格控件)中实现图像数据列的动态保存,以及与CxImage控件相结合处理粘贴剪切板图片的功能。作者土豆散在2018年4月23日分享了这段代码片段。 首先,当检测到剪贴板中的内容可用(在这里是CF_BITMAP格式,即位图格式),程序会创建一个TBitmap对象(aMap)和一个TJpegImage对象(aJpg)。接下来,从剪贴板获取数据并将其复制到aMap中,然后将这个位图转换为Jpg格式,以便在CxImage控件(ImgPicture.Picture)上显示图片。通过调用Graphic的SaveToStream方法,图片被保存到一个TMemoryStream(aStream)中。 重点在于处理焦点行(RecIdx <> -1),这意味着只有当用户在网格中有选中行时,才会进行图像保存操作。这里,将图片数据(GoodsPicture)作为变量存储,其类型是通过StreamToVariant函数将内存流转换得到的可变类型。最后,代码更新了数据控制器(cxGrid1TableView1.DataController)中的指定单元格(第26列,假设是图片列,数据类型为BLOB),并将保存的图片数据赋值给该单元格。同时,为了提高性能,还调用了BeginFullUpdate方法来开启数据的全更新模式。 值得注意的是,如果需要支持CF_PICTURE格式的图片,代码中有一处注释掉的部分,表明可能存在对这种格式的支持。然而,实际操作中,可能更常见的是位图格式的图片,如Excel导入的图片。 这段代码提供了一个实用的例子,展示了如何在Delphi应用中利用CxGrid和相关控件处理和保存图像数据,适用于需要与剪贴板交互或在表格中动态展示图片的场景。对于开发人员来说,理解和调整此代码有助于在项目中实现类似功能。
2017-08-24 上传
一些Delphi7的例子,包含下面内容:(高手就别看了,新手可看看,也是好多年没做了,又要做个小东西,练手做的例子) 有的是本人练习做的,少数是下载别人的或修改过的,也有1个似乎是明日科技的配套代码-此处没有删除,懒得删除直接打包了。 用这些分,只是用来备用下载其他东西而用,你觉得不值得,你留言分退给你(我来也不是常来这里),我认为是值得的。 还有一些其他的清单没罗列出来 如数据库表结构找不到,根据名字找这个文件名:EquipmentSQL_20170528_ok, 如果没就是没有了,因为一个连接服务器,一个是本机上的练习数据库,如没有请见谅 大致类型: cxGrid的几个例子、ini连接数据库、明日科技配套代码(文件上传下载)、 时间差相减(可参考Delphi函数里面的综合运用)、基本控件应用 cxGrid查找功能 cxGrid的列属性 cxGrid应用交流实例一_ok eg_Add_cbbValue_IntoMemo_test_20170401 eg_Check_Checkbox_Change eg_counter eg_cxGrid_Right_2 eg_cxGrid_Right_更细权限的bit值到表中 eg_cxGrid_SumRecord_1 eg_DCom_connection_20170606 eg_ImportToSQL eg_LoadRecord_Improve_Original eg_LoadRZCheckTree_1 eg_LoadRZCheckTree_连带设置_2 eg_LoadRZCheckTree_双击用户设置_del eg_LoadTree_1 eg_ReadIni_独立数据模块 eg_test_ImportExcelToSQL_ComOBJ_2 eg_update_bit_20170528 eg_报废时间月日格式只有1位时问题_20170609 eg_测试某列的条件改变另外列的Edit属性(cxGrid的例子) eg_对BoolToStr后的值进行再次转换_最后循环取bit值 eg_时间差计算_2 FileMS(明日科技的配套代码,关于文件上传下载的那个) EquipmentSQL_20170528_ok(如没数据库的,在这里查表结构,有的表结构不在这里,只能参考一下了)