Foxtable(狐表)用户栏目专家坐堂 → [求助] 要实现单元格直接显示图片,鼠标进入弹出大图,这段代码怎么总是出错呢?


  共有3618人关注过本帖树形打印复制链接

主题:[求助] 要实现单元格直接显示图片,鼠标进入弹出大图,这段代码怎么总是出错呢?

美女呀,离线,留言给我吧!
龙潭春早
  1楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:676 积分:4895 威望:0 精华:0 注册:2018/3/22 16:05:00
[求助] 要实现单元格直接显示图片,鼠标进入弹出大图,这段代码怎么总是出错呢?  发帖心情 Post By:2019/7/21 15:53:00 [只看该作者]

一、问题

设置了远程文件的图片扩展列“测试FTP”和 FTP,已经能够上传图片,使用正常

现在希望在该列实现单元格直接显示图片,并且鼠标进入时弹出大图。

参照此前论坛上甜老师给他人的一个回帖,设置了以下的代码,但是总是报错,为什么呢?

图片点击可在新窗口打开查看此主题相关图片如下:单元格绘制图片报错drawcell(1).jpg
图片点击可在新窗口打开查看

图片点击可在新窗口打开查看此主题相关图片如下:单元格绘制图片报错drawcell(2).jpg
图片点击可在新窗口打开查看

二、弹出窗口的设置

       1)窗口名称:测试 FTP 图片伸缩

       2)窗口内设置了控件:PictureBox1

       3)窗口AfterLoad事件代码
e.Form.BaseForm.FormBorderStyle = System.Windows.Forms.FormBorderStyle.None

三、表事件代码

1、StartEdit事件

Dim frm = Forms("测试 FTP 图片伸缩")
If frm.opened Then
    frm.baseform.left = -1000
    frm.baseform.Top = -1000
End If

2、Drawcell事件 —— 总是在这个事件上报错!

If e.Col.name = "测试FTP" Then
    e.StartDraw
    If e.Row("测试FTP") > ""  Then
        Dim Ls = e.Row.DataRow.Lines("测试FTP")
        e.Graphics.DrawImage(getimage(projectPath & "RemoteFiles\测试\" & Ls(0)), e.x + 3,e.y + 3, 50, 50)  ' 绘制第一个图标
    End If
    e.text = ""
    e.EndDraw
End If

3、MouseEnterCell事件

Dim frm = Forms("测试 FTP 图片伸缩")
If frm.opened = False Then
    frm.open
End If
If e.Col.name = "测试FTP" AndAlso e.Row("测试FTP") > "" Then
    frm.baseform.left = System.Windows.Forms.Cursor.Current.Position.X + 5
    frm.baseform.Top = System.Windows.Forms.Cursor.Current.Position.Y + 5
    e.Table.Focus
        Dim Ls = e.Row.DataRow.Lines("测试FTP")
        'output.show(Ls(0))
    frm.controls("picturebox1").image = getimage(projectPath & "RemoteFiles\测试\" & Ls(0))
Else
    frm.baseform.left = -1000
    frm.baseform.Top = -1000
End If

4、MouseLeaveCell事件
Dim frm = Forms("测试 FTP 图片伸缩")
If e.Col.name <> "测试FTP" AndAlso frm.opened Then
    frm.baseform.left = -1000
    frm.baseform.Top = -1000
    
End If

四、参考的实例图片

图片点击可在新窗口打开查看此主题相关图片如下:单元格绘制图片报错drawcell(3).jpg
图片点击可在新窗口打开查看







[此贴子已经被作者于2019/7/21 16:01:12编辑过]

 回到顶部
帅哥,在线噢!
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110528 积分:562524 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/7/21 21:10:00 [只看该作者]

If e.Col.name = "测试FTP" Then
    e.StartDraw
    If e.Row("测试FTP") > ""  Then
        Dim Ls = e.Row.DataRow.Lines("测试FTP")
        If FileSys.FileExists(projectPath & "RemoteFiles\测试\" & Ls(0)) Then '如果文件存在
            e.Graphics.DrawImage(getimage(projectPath & "RemoteFiles\测试\" & Ls(0)), e.x + 3,e.y + 3, 50, 50)  ' 绘制第一个图标
        End If
    End If
    e.text = ""
    e.EndDraw
End If

 回到顶部
美女呀,离线,留言给我吧!
龙潭春早
  3楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:676 积分:4895 威望:0 精华:0 注册:2018/3/22 16:05:00
  发帖心情 Post By:2019/7/21 21:59:00 [只看该作者]

好一点儿,不报错了。

但还是不行,单元格和弹出的窗口里,都没显示图片。

鼠标进入单元格,弹出的窗口中没有图片:

图片点击可在新窗口打开查看此主题相关图片如下:单元格绘制图片报错drawcell(4).jpg
图片点击可在新窗口打开查看

点击单元格按钮,弹出的窗口能正常显示图片:

图片点击可在新窗口打开查看此主题相关图片如下:单元格绘制图片报错drawcell(5).jpg
图片点击可在新窗口打开查看

[此贴子已经被作者于2019/7/21 22:07:00编辑过]

 回到顶部
帅哥,在线噢!
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110528 积分:562524 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/7/21 22:52:00 [只看该作者]

说明图片还没有下载到本地。如果是远程网络下载是需要一定的时间的。

 回到顶部
帅哥哟,离线,有人找我吗?
yifan3429
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2482 积分:22932 威望:0 精华:0 注册:2011/3/29 17:14:00
  发帖心情 Post By:2019/7/21 22:55:00 [只看该作者]

单元表显示图片功能 可以分享吗

 回到顶部
帅哥,在线噢!
有点蓝
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110528 积分:562524 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/7/21 22:57:00 [只看该作者]

以下是引用yifan3429在2019/7/21 22:55:00的发言:
单元表显示图片功能 可以分享吗

1楼不是已经给出完整的用法了吗

 回到顶部
美女呀,离线,留言给我吧!
龙潭春早
  7楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:676 积分:4895 威望:0 精华:0 注册:2018/3/22 16:05:00
  发帖心情 Post By:2019/7/22 1:37:00 [只看该作者]

以下是引用有点蓝在2019/7/21 22:52:00的发言:
说明图片还没有下载到本地。如果是远程网络下载是需要一定的时间的。

蓝老师,之前在本地的 "RemoteFiles\测试\" 目录之下,已经有这些图片了,应该是已经下载下来了。 只是奇怪为什么单元格却不显示?

 回到顶部
美女呀,离线,留言给我吧!
龙潭春早
  8楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:676 积分:4895 威望:0 精华:0 注册:2018/3/22 16:05:00
  发帖心情 Post By:2019/7/22 1:43:00 [只看该作者]

以下是引用yifan3429在2019/7/21 22:55:00的发言:
单元表显示图片功能 可以分享吗

1楼的那些,就是完整的代码。

 回到顶部
帅哥,在线噢!
有点蓝
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110528 积分:562524 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/7/22 8:46:00 [只看该作者]

projectPath & "RemoteFiles\测试\" & Ls(0)

路径是否正确,是否存在此文件

 回到顶部
美女呀,离线,留言给我吧!
龙潭春早
  10楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:676 积分:4895 威望:0 精华:0 注册:2018/3/22 16:05:00
  发帖心情 Post By:2019/7/22 13:45:00 [只看该作者]

蓝老师,路径 "RemoteFiles\测试\" 是从Windows资源管理器的地址栏里直接复制来的,直接隶属于项目路径,应该都没有错。

文件 Ls(0) 是定义的字符集合调用的第一个图片,应该也没有错。只要单元格中有图片文件,就应该能够调用。

从下面的截屏中也可以看出,路径 "RemoteFiles\测试\" 下,确实存在不少图片文件。

您看:

图片点击可在新窗口打开查看此主题相关图片如下:单元格绘制图片报错drawcell(6).jpg
图片点击可在新窗口打开查看

还请蓝老师多费心,再帮着找找原因图片点击可在新窗口打开查看


 回到顶部
总数 24 1 2 3 下一页