Foxtable(狐表)用户栏目专家坐堂 → [求助] 填充颜色


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

主题:[求助] 填充颜色

帅哥哟,离线,有人找我吗?
leoli
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:小狐 帖子:301 积分:2547 威望:0 精华:0 注册:2018/11/15 12:35:00
[求助] 填充颜色  发帖心情 Post By:2019/7/28 22:27:00 [只看该作者]

你好,最近购买了个这个Foxtable,可是还不怎么会用,按照售后服务的推荐,请这儿的老师帮忙一下,谢谢。

 

表中的第一列我用 扩展例类型 设定了 色彩。

 

要求,在窗口中按一下按钮可实现 :

 

1. 当第二列,第三列,第四列 中的数量是空白 或 是 0 时,第一列就显示 蓝色

 

2. 当第三列,第四列 中的数量是空白 或 是 0 时,第一列就显示 绿色

 

3. 当第三列的数量大于0,第四列 中的数量是空白 或 是 0 时,第一列就显示 橙色

 

4. 当第四列的数量大于0时,第一列就显示 红色

 

带上例子,请帮忙看一下。谢谢。

 

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:填充颜色.table


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


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

例如

datacolchanged事件

Select e.DataCol.Name
    Case "第二列","第三列","第四列"
        If e.DataRow("第二列") = 0 AndAlso e.DataRow("第三列") = 0 AndAlso e.DataRow("第四列") = 0 Then
            e.DataRow("第一列") = Color.blue.Toargb
        ElseIf  e.DataRow("第三列") = 0 AndAlso e.DataRow("第四列") = 0 Then
            e.DataRow("第一列") = Color.green.Toargb
        End If
End Select

其它两种颜色代码自己学着补充上去

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


加好友 发短信
等级:小狐 帖子:301 积分:2547 威望:0 精华:0 注册:2018/11/15 12:35:00
  发帖心情 Post By:2019/7/28 23:25:00 [只看该作者]

你好,不对,第一次可以,可是在表里任意修改后,不会变更了。

 

可以用按钮来实现吗?

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:填充颜色.table


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


加好友 发短信
等级:狐神 帖子:4649 积分:33907 威望:0 精华:0 注册:2008/8/31 22:44:00
  发帖心情 Post By:2019/7/29 8:23:00 [只看该作者]

Select e.DataCol.Name
    Case "第二列","第三列","第四列"
        If e.DataRow("第三列") = 0 AndAlso e.DataRow("第四列") = 0
            e.DataRow("第一列") = Color.Orange.Toargb
        ElseIf  e.DataRow("第二列") = 0 AndAlso e.DataRow("第三列") = 0 AndAlso e.DataRow("第四列") = 0
            e.DataRow("第一列") = Color.green.Toargb
        ElseIf  e.DataRow("第三列") = 0 AndAlso e.DataRow("第四列") = 0
            e.DataRow("第一列") = Color.Orange.Toargb
        ElseIf e.DataRow("第四列") > 0
            e.DataRow("第一列") = Color.red.Toargb
        End If
End Select

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


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

代码放到datacolchanged事件,而不是datacolchanging事件。

Foxtable不同事件有不同的使用场合,不是随便使用的

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


加好友 发短信
等级:小狐 帖子:301 积分:2547 威望:0 精华:0 注册:2018/11/15 12:35:00
  发帖心情 Post By:2019/7/29 10:23:00 [只看该作者]

谢谢,老师

 

那如何转换成按钮代码

 

Select e.DataCol.Name
    Case "第二列","第三列","第四列"
        If e.DataRow("第三列") = 0 AndAlso e.DataRow("第四列") = 0
            e.DataRow("第一列") = Color.Orange.Toargb
        ElseIf  e.DataRow("第二列") = 0 AndAlso e.DataRow("第三列") = 0 AndAlso e.DataRow("第四列") = 0
            e.DataRow("第一列") = Color.green.Toargb
        ElseIf  e.DataRow("第三列") = 0 AndAlso e.DataRow("第四列") = 0
            e.DataRow("第一列") = Color.Orange.Toargb
        ElseIf e.DataRow("第四列") > 0
            e.DataRow("第一列") = Color.red.Toargb
        End If
End Select


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


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

dim r as row = tables("表A").current
if r isnot nothing then
    If r("第三列") = 0 AndAlso r("第四列") = 0
            r("第一列") = Color.Orange.Toargb
    elseif ............
end if

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


加好友 发短信
等级:狐神 帖子:4649 积分:33907 威望:0 精华:0 注册:2008/8/31 22:44:00
  发帖心情 Post By:2019/7/29 10:51:00 [只看该作者]

For Each dr As DataRow In DataTables("表A").DataRows
    If dr("第二列") = 0 AndAlso  dr("第三列") = 0 AndAlso dr("第四列") = 0
        dr("第一列") = Color.green.Toargb
    ElseIf  dr("第三列") = 0 AndAlso dr("第四列") = 0
        dr("第一列") = Color.Orange.Toargb
    ElseIf dr("第四列") > 0
        dr("第一列") = Color.red.Toargb
    ElseIf dr("第三列") = 0 AndAlso dr("第四列") = 0
        dr("第一列") = Color.Orange.Toargb
    End If
Next

 回到顶部