且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

用C#显示Project2007+TFS2008结合后的实时项目进度

更新时间:2022-09-17 21:58:51

前期说明:在Project2007中可以选择一个团队项目(TFS),然后在Project2007中排好进度,作为工作项发布到TFS服务器上。之后可以直接作为工作项在VS2005等工具中填写项目进度。本文的目的就是要显示出TFS中保存的实时项目进度情况等。
技术说明:在Project2007之前的版本可以通过oledb的方式直接读取project的mpp文件来显示进度,在project2007时不再提供oledb的方式了,可能的两种实现方法有:
1、使用Project2007提供的COM接口,读取mpp文件中的任务 + TFS中的实时进度
2、把所有的进度安排(包括父任务)发布到TFS中,直接读取TFS中的实时进度

一、COM接口的方式
用C#显示Project2007+TFS2008结合后的实时项目进度Code
这种方式我就不具体说了,可以看代码中的注释。采用这种方式有几个问题:
速度比较慢;b/s结构时有点问题;
经常报错:异常详细信息:   System.Runtime.InteropServices.COMException:   消息筛选器显示应用程序正在使用中。试了一些解决方案,好像都不行的。

二、直接读取TFS的方式
主意思路是:在TFS中定制一个新的工作项类型,其中包含一个新的工作项字段(项目分解结构);设置Project和TFS之间同步哪些字段,把新的字段包含进去;在Project中使用这个新的工作项类型;使用TFS SDK读出进度情况。
主要分成以下几个步骤进行:
(以下的command命令都是在VS2005命令提示窗口输入的)、
1、加入新的工作项类型
用以下命令导出原有的工作项类型:
用C#显示Project2007+TFS2008结合后的实时项目进度witexport /"E:\scheduletask.xml" /http://server:8080/ /p projectname /"任务"用C#显示Project2007+TFS2008结合后的实时项目进度
然后编辑这个xml文件,以下文件中红色的部分是修改的地方:
用C#显示Project2007+TFS2008结合后的实时项目进度工作项类型
然后用以下命令把它加入到tfs中去:
用C#显示Project2007+TFS2008结合后的实时项目进度witimport /"E:\\scheduletask.xml" /"http://server:8080/" /p projectname
这样我们就增加了一个新的工作项类型:进度,和一个新的工作项字段:Microsoft.VSTS.Scheduling.WBS

2、确定TFS和project之间可以同步哪些字段
首先下载原有配置:
用C#显示Project2007+TFS2008结合后的实时项目进度TFSFieldMapping.exe download http://server:8080 projectname  "E:\MappingFile.xml"用C#显示Project2007+TFS2008结合后的实时项目进度
在原有配置上修改,见红色部分:
用C#显示Project2007+TFS2008结合后的实时项目进度TFS配置
再把配置文件上传:
用C#显示Project2007+TFS2008结合后的实时项目进度TFSFieldMapping.exe upload http://server:8080 projectname  "E:\MappingFile.xml"
这样就把TFS字段和project中的指定字段对应起来了

三、在project中使用"进度"工作项类型
这一步比较简单,就是在project中选择团队项目,排计划时选择"进度"类型,然后发布到tfs中就可以了

四、使用tfs SDK读取进度
就是使用TFS SDK就可以了:
用C#显示Project2007+TFS2008结合后的实时项目进度        private void BindTfs()
用C#显示Project2007+TFS2008结合后的实时项目进度        
{
用C#显示Project2007+TFS2008结合后的实时项目进度            ArrayList taskList 
= new ArrayList();
用C#显示Project2007+TFS2008结合后的实时项目进度
用C#显示Project2007+TFS2008结合后的实时项目进度            StringBuilder sbSql 
= new StringBuilder();
用C#显示Project2007+TFS2008结合后的实时项目进度            sbSql.Append(
"Select [Microsoft.VSTS.Scheduling.RemainingWork],[Microsoft.VSTS.Scheduling.CompletedWork]");
用C#显示Project2007+TFS2008结合后的实时项目进度            sbSql.Append(
",[System.Title]");
用C#显示Project2007+TFS2008结合后的实时项目进度            sbSql.Append(
",[System.AssignedTo]");
用C#显示Project2007+TFS2008结合后的实时项目进度            sbSql.Append(
",[Microsoft.VSTS.Scheduling.StartDate]");
用C#显示Project2007+TFS2008结合后的实时项目进度            sbSql.Append(
",[Microsoft.VSTS.Scheduling.FinishDate]");
用C#显示Project2007+TFS2008结合后的实时项目进度            sbSql.Append(
",[Microsoft.VSTS.Scheduling.WBS]");
用C#显示Project2007+TFS2008结合后的实时项目进度            sbSql.Append(
" from workitems where [System.WorkItemType]='进度' ");
用C#显示Project2007+TFS2008结合后的实时项目进度            sbSql.Append(
" order by [Microsoft.VSTS.Scheduling.WBS]");
用C#显示Project2007+TFS2008结合后的实时项目进度            WorkItemStore Store 
= new WorkItemStore(tfsServer);
用C#显示Project2007+TFS2008结合后的实时项目进度            WorkItemCollection wicollection 
= Store.Query(sbSql.ToString());
用C#显示Project2007+TFS2008结合后的实时项目进度            
foreach (WorkItem item in wicollection)
用C#显示Project2007+TFS2008结合后的实时项目进度            
{
用C#显示Project2007+TFS2008结合后的实时项目进度                ProTask proTask 
= new ProTask();
用C#显示Project2007+TFS2008结合后的实时项目进度
用C#显示Project2007+TFS2008结合后的实时项目进度                
//当前进度
用C#显示Project2007+TFS2008结合后的实时项目进度
                string strRate = "";
用C#显示Project2007+TFS2008结合后的实时项目进度                
float RemainingWork = Convert.ToSingle(item["Microsoft.VSTS.Scheduling.RemainingWork"]);
用C#显示Project2007+TFS2008结合后的实时项目进度                
float CompletedWork = Convert.ToSingle(item["Microsoft.VSTS.Scheduling.CompletedWork"]);
用C#显示Project2007+TFS2008结合后的实时项目进度                
if ((int)CompletedWork == 0)
用C#显示Project2007+TFS2008结合后的实时项目进度                
{
用C#显示Project2007+TFS2008结合后的实时项目进度                    strRate 
= "0%";
用C#显示Project2007+TFS2008结合后的实时项目进度                }

用C#显示Project2007+TFS2008结合后的实时项目进度                
else if ((int)RemainingWork == 0)
用C#显示Project2007+TFS2008结合后的实时项目进度                
{
用C#显示Project2007+TFS2008结合后的实时项目进度                    strRate 
= "100%";
用C#显示Project2007+TFS2008结合后的实时项目进度                }

用C#显示Project2007+TFS2008结合后的实时项目进度                
else
用C#显示Project2007+TFS2008结合后的实时项目进度                
{
用C#显示Project2007+TFS2008结合后的实时项目进度                    
float Rate = CompletedWork / (CompletedWork + RemainingWork);
用C#显示Project2007+TFS2008结合后的实时项目进度                    Rate 
= Rate * 100;
用C#显示Project2007+TFS2008结合后的实时项目进度                    strRate 
= Convert.ToString(Rate);
用C#显示Project2007+TFS2008结合后的实时项目进度                    
if (strRate.Length > 2)
用C#显示Project2007+TFS2008结合后的实时项目进度                    
{
用C#显示Project2007+TFS2008结合后的实时项目进度                        strRate 
= strRate.Substring(02);
用C#显示Project2007+TFS2008结合后的实时项目进度                    }

用C#显示Project2007+TFS2008结合后的实时项目进度                    strRate 
= strRate + "%";
用C#显示Project2007+TFS2008结合后的实时项目进度                }

用C#显示Project2007+TFS2008结合后的实时项目进度                proTask.PCT 
= strRate;
用C#显示Project2007+TFS2008结合后的实时项目进度
用C#显示Project2007+TFS2008结合后的实时项目进度                proTask.TaskName 
= item.Title;
用C#显示Project2007+TFS2008结合后的实时项目进度                proTask.StartDate 
= Convert.ToDateTime(item["Microsoft.VSTS.Scheduling.StartDate"]);
用C#显示Project2007+TFS2008结合后的实时项目进度                proTask.FinishDate 
= Convert.ToDateTime(item["Microsoft.VSTS.Scheduling.FinishDate"]);
用C#显示Project2007+TFS2008结合后的实时项目进度                proTask.Resources 
= item["System.AssignedTo"].ToString();
用C#显示Project2007+TFS2008结合后的实时项目进度                proTask.WBS 
= item["Microsoft.VSTS.Scheduling.WBS"].ToString();
用C#显示Project2007+TFS2008结合后的实时项目进度                taskList.Add(proTask);
用C#显示Project2007+TFS2008结合后的实时项目进度            }

用C#显示Project2007+TFS2008结合后的实时项目进度
用C#显示Project2007+TFS2008结合后的实时项目进度
用C#显示Project2007+TFS2008结合后的实时项目进度            gvTask.DataSource 
= taskList;
用C#显示Project2007+TFS2008结合后的实时项目进度            gvTask.DataBind();
用C#显示Project2007+TFS2008结合后的实时项目进度        }

附:
在浏览所有进度时出现问题:拒绝访问(The work item does not exist, or you do not have permission to access it. )

原因:tfs装的是90天测试版,在过期时把日期改为之前两个月了,导致进度这个工作项的加入时间和系统时间有冲突,将系统时间改为工作项加入之后的时间,重启iis就可以了



    本文转自永春博客园博客,原文链接:http://www.cnblogs.com/firstyi/archive/2008/04/10/1140897.html,如需转载请自行联系原作者