以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  [求助]绘图依据开始和结束时间  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=83416)

--  作者:狐作非为
--  发布时间:2016/4/8 13:32:00
--  [求助]绘图依据开始和结束时间


图片点击可在新窗口打开查看此主题相关图片如下:绘.png
图片点击可在新窗口打开查看

保留现有的功能,调整开始时间后,单元格的x坐标按开始时间来画,请问该如何修正?
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:管理项目_绘图.zip


[此贴子已经被作者于2016/4/8 13:32:36编辑过]

--  作者:大红袍
--  发布时间:2016/4/8 14:54:00
--  
If e.Col.name.StartsWith("时_") Then
    e.StartDraw()
    Dim ts As Date = e.Row("开始时间")
    Dim te As Date = e.Row("结束时间")
    Dim t As Integer = e.Col.Name.Replace("时_", "")
    Dim tt As Date = new Date(1, 1, 1, 8, 0, 0)
    Dim sp1 As TimeSpan = ts - tt
    Dim sp2 As TimeSpan = te - tt
    If sp1.TotalMinutes < t AndAlso sp1.TotalMinutes >= t-60 Then
        Dim x As Integer = ts.Minute * e.width / 60
        Dim width As Integer = (sp2.TotalMinutes - sp1.TotalMinutes) * e.width / 60
        e.Graphics.FillRectangle(Brushes.Green,e.x + x + 1,e.y + 1, Width, e.Height - 2)
    ElseIf t-60 > sp1.TotalMinutes AndAlso t-60 < sp2.TotalMinutes Then
        Dim x As Integer = 0
        Dim width As Integer = (sp2.TotalMinutes - t + 60) * e.width / 60
        e.Graphics.FillRectangle(Brushes.Green,e.x + x + 1,e.y + 1, Width, e.Height - 2)
    End If
    e.EndDraw()
End If

--  作者:狐作非为
--  发布时间:2016/4/8 15:05:00
--  
感谢狐版,这样貌似不对,前面的条件还是要的,必须是项目相同且在同一日期下才会是接上一行的开始时间
--  作者:大红袍
--  发布时间:2016/4/8 15:12:00
--  
以下是引用狐作非为在2016/4/8 15:05:00的发言:
感谢狐版,这样貌似不对,前面的条件还是要的,必须是项目相同且在同一日期下才会是接上一行的开始时间

 

汗,你能不能理清思路啊,根据你的开始时间、结束时间画啊。时间你怎么调整是你自己的事