开发背景

最近在使用微软的Office Project 2010 进行项目管理,看到排的满满的计划任务,一个个地被执行完毕,还是很有成就感的。其实,不光是在工作中可以使用Project进行项目进度控制,同样可以把这款软件应用在日常的生活中,比如为阅读某本书排一个计划,而任务单元就是本书的目录,当然粒度可以自己定制;也可以为健身排一个计划,每周去几次健身房、每次做多少个动作、做什么类型的动作,都可以提前排程,每完成一项就就在任务进度上狠狠地输入100%,那是多么爽的事啊。

但是,通过一段时间的使用,我发现自己有一个个性化的需求,就是习惯为各种状态的任务加上不同的背景色,这样就会很清晰直观地掌握任务的总体完成情况;还有就是很不喜欢Project自带的创建任务的方式,希望可以以自己的方式来创建任务,比如任务的资源一般是我自己的名字(大多数情况),所以我希望创建任务的时候,默认带出资源名称,再比如我喜欢用微软雅黑作为默认字体,但是每次都是设置好单个单元格后,再用格式刷去刷,很是麻烦,再比如表示任务状态的背景色,也是自己一点点用格式刷去刷的,如果不常用这个工具还好,但是总是这样难免让人反感,所以就产生了这个想法。以上就是我自己的个性化需求,如果后续有其他想法,还可以自己扩展,把懒人的风格发扬到底。在园子里也找了一些相关资料,但是和我的出发点都不是很吻合,所以废话不多说,自己动手,丰衣足食。

Project Object 模型

之前做过Word的插件开发,里面的各个组件(Range,Paragraph,Selection)等都是有规律可循的,大多数对象都有自己的集合,而且多个对象之间的关联比较密切,但是Project的模型让我很费解,比如里面的单元格Cell,居然不存在集合的概念(见微软官方文档),这里面比较重要的模型有以下几个:Application、Task、Cell、Resource等,当然,还有其他的比较重要的模型,只是不是很常用,在此不做说明。

Represents the active cell. (There is no collection for Cell objects.) The Cell object can be accessed only through the ActiveCell property of the Application object.

Represents a task. The Task object is a member of the Tasks collection.

Use Tasks(Index), where Index is the task index number or task name, to return a single Task object. The following example prints the name of every resource assigned to every task in the active project.

创建自定义任务窗口

还是先来看下自定义的创建任务窗口,效果如下:

由于我的个性化需求不是很复杂,就简单地创建了一个存储常用字段的Model,主要包括Task的常用属性,比如任务名称、工期、起止时间、资源以及完成百分比。以下是添新任务的代码段:

 private void Create_Click(object sender, EventArgs e)
{
if (string.IsNullOrEmpty(taskName.Text)) return;
Project proj = Globals.ThisAddIn.Application.ActiveProject;
TaskModel.TaskModel taskModel = new TaskModel.TaskModel
{
TaskName = taskName.Text,
TaskDuring = taskDuring.Value.ToString(),
ResourceNames = taskResource.Text,
Notes = taskNotes.Text
}; Application_NewProject(proj, taskModel);
}

Application_NewProject接受一个当前的ActiveProject对象和一个TaskModel对象,代码如下:

 private void Application_NewProject(Microsoft.Office.Interop.MSProject.Project pj, TaskModel.TaskModel taskModel)
{
object missing = Type.Missing;
TaskModel.TaskModel tm = taskModel;
Microsoft.Office.Interop.MSProject.Task newTask = pj.Tasks.Add(tm.TaskName, missing);
newTask.Start = DateTime.Now;
newTask.Duration = tm.TaskDuring;
newTask.ResourceNames = tm.ResourceNames.ToString();
newTask.Notes = tm.Notes;
}

新增Task是通过Project对象的Tasks属性的Add方法添加的。Task还有很多其他的属性,在此也不一一列举。

更清晰地展现任务进度

先看下整体的效果图:

在使用插件处理前基本是这样的

在使用插件处理后是这样的,预设好的背景色、字体、状态等。

这样一键处理后,看起来舒服多了,每项任务都有三个状态,即【准备】、【执行】、【完成】。【准备】对应背景色为红色,【执行】对应背景色为黄色,【完成】对应背景色为绿色,这样就会对项目任务进度的大概完成程度有一个直观的把握。相对于格式刷子来说还是很方便的。

下面是部分代码:

 /// <summary>
/// 根据任务状态进行背景填充的核心方法
/// </summary>
private void CallSelectTaskField()
{
foreach (Task task in Globals.ThisAddIn.Application.ActiveProject.Tasks)
{
Globals.ThisAddIn.Application.SelectTaskField(task.Index, "名称", false, , );
if (task.PercentComplete == )
{
CallFont32Ex(CommonData.MappingColorState(CommonData.TaskState.Ready));
}
else if (task.PercentComplete == )
{
CallFont32Ex(CommonData.MappingColorState(CommonData.TaskState.Complete));
}
else
{
CallFont32Ex(CommonData.MappingColorState(CommonData.TaskState.Processing));
}
}
}

上面的代码中涉及到两个个核心模型,一个是Application,这是整个应用程序级别的对象,很多东西都封装在里面,包括ActiveCell、ActiveSelection、ActiveWindow以及上面代码中的ActiveProject,具体的成员请看这里;还有一个就是Task,Task模型对应的是Project中一条条的任务,它的很多成员都是动态类型(Dynamic),具体模型在这里,成员在这里。代码中从当前活动的Project中获取所有Task集合,并判断每一条Task的PercentComplete(完成百分比)属性,根据未开始、执行中和已完成几个状态来设置每一条Task背景色。开始时,我以为Task会存在一个背景色Background属性,但是并没有,而是通过选择一段Filed,然后针对该段Filed调用Font32Ex方法进行设置的。

在这个功能点上,还是遇到了很多麻烦,走了很多弯路,比如刚开始的时候,并不是采用Font32Ex方法来填充任务背景色的,而是用的TextStyle方法,这个方法的第一个参数是一个枚举,在填充背景色功能点上,只有第一个枚举生效了(其他也有,但是没有一个个尝试,枚举比较多),后来就采用录制宏的方式来解决,以下是宏代码:

 Sub Macro1()
' 宏 Macro1
' Xuhbd 在 2016年12月12日 记录的宏。
SelectRow Row:=
OutlineIndent
Font32Ex CellColor:=
End Sub

在这段宏代码中,明显看到了Font32Ex这个方法,但是看了官方提供的文档,其中有一个参数是CellColor,要求的对象是pjColor枚举,运行后发现被填充的背景色都是黑色,无论选择什么颜色。

后来我就把pjColor直接用Color替换,居然成功了。

代码如下:

 /// <summary>
/// 调用系统方法设置背景色
/// </summary>
/// <param name="bgColor"></param>
private void CallFont32Ex(Color bgColor)
{
object missing=Type.Missing;
Globals.ThisAddIn.Application.Font32Ex(
"微软雅黑", , missing, missing,
missing, missing, missing,
bgColor, missing, missing);
}

结语

通过完成这个Project的插件,学习了Project 模型,同时让我更加方便地使用Project,提高了积极性,如果有新的需求可以在这个基础上进行扩展,这样就形成了良性循环。在这个过程中,参考了很多的微软官方文档(而且是英文的,看来英文学习很重要啊),最后,代码已经托管到GitHub上,文中表述如果什么问题,请大家留言,我会及时更正。

Porject Addin Download

作者:悠扬的牧笛

博客地址:http://www.cnblogs.com/xhb-bky-blog/p/6155809.html

声明:本博客原创文字只代表本人工作中在某一时间内总结的观点或结论,与本人所在单位没有直接利益关系。非商业,未授权贴子请以现状保留,转载时必须保留此段声明,且在文章页面明显位置给出原文连接。

【原创】记一次Project插件开发的更多相关文章

  1. 记一次Project插件开发

    一.开发背景 最近在使用微软的Office Project 2010 进行项目管理,看到排的满满的计划任务,一个个地被执行完毕,还是很有成就感的.其实,不光是在工作中可以使用Project进行项目进度 ...

  2. [原创]记一次java执行段错误及解决过程

    最近一周左右,网管监控系统经常监控到tomcat异常退出,由于有检测tomcat pid的脚本,所以会自动重启服务器,查询tomcat日志没有报错信息,查询系统message日志,可以看到如下信息. ...

  3. Atitit.hybrid混合型应用 浏览器插件,控件的实现方式 浏览器运行本地程序的解决方案大的总结---提升用户体验and开发效率..

    Atitit.hybrid混合型应用 浏览器插件,控件的实现方式 浏览器运行本地程序的解决方案大的总结---提升用户体验and开发效率.. 1. hybrid App 1 1.1. Hybrid Ap ...

  4. @RISK

    Price: AUD $3,295.00   Price: AUD $2,495.00   适用于项目管理的 @RISK 免费试用版下载 » 立即购买 » 价格对比 » 许可选项 (英文) » 教学计 ...

  5. .net core 连接mysql

    Package引入: mysql.data MySql.Data.EntityFrameworkCore Pomelo.EntityFrameworkCore.MySql 2. 在package ma ...

  6. 记一个mvn奇怪错误: Archive for required library: 'D:/mvn/repos/junit/junit/3.8.1/junit-3.8.1.jar' in project 'xxx' cannot be read or is not a valid ZIP file

    我的maven 项目有一个红色感叹号, 而且Problems 存在 errors : Description Resource Path Location Type Archive for requi ...

  7. [非原创]Project facet Java version 1.8 is not supported解决记录

    原博地址:http://blog.csdn.net/dingchenxixi/article/details/51496998 一看知道是因为jdk版本不一致所导致,如何解决? 方法一: 选中项目 P ...

  8. eclipse弃坑记第一篇之在idea上配置Tomcat环境并创建Javaweb项目的详细步骤原创

    IntelliJ IDEA是一款功能强大的开发工具,在代码自动提示.重构.J2EE支持.各类版本工具(如git.svn.github).maven等方面都有很好的应用. IntelliJ IDEA有免 ...

  9. MySQL用source命令导入不记入binlog中【原创】

    试验环境,MySQL主主复制 主库10.72.16.112 从库10.72.16.50 一直有个疑问,利用sql_log_bin=0可以临时在客户端停止将操作记入binlog中,如果使用source命 ...

随机推荐

  1. JavaScript之父Brendan Eich,Clojure 创建者Rich Hickey,Python创建者Van Rossum等编程大牛对程序员的职业建议

    软件开发是现时很火的职业.据美国劳动局发布的一项统计数据显示,从2014年至2024年,美国就业市场对开发人员的需求量将增长17%,而这个增长率比起所有职业的平均需求量高出了7%.很多人年轻人会选择编 ...

  2. Springmvc数据校验

    步骤一:导入四个jar包 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns=" ...

  3. DB1:数据库的创建和文件的修改

    在SQL Server中,使用Create Database创建数据库,使用Alter Database命令,能够修改数据库的数据文件和日志文件. 一,创建数据库 1,在创建数据库时,最佳实践是: 创 ...

  4. MVVM TextBox的键盘事件

    MVVM下RichTextBox的键盘回车事件设置为发送,不是回车 xmlns:i="http://schemas.microsoft.com/expression/2010/interac ...

  5. 使用Java原生代理实现AOP

    ### 本文由博主柒.原创,转载请注明出处 ### 完整源码下载地址 [https://github.com/MatrixSeven/JavaAOP](https://github.com/Matri ...

  6. app引导页(背景图片切换加各个页面动画效果)

    前言:不知不觉中又加班到了10点半,整个启动页面做了一天多的时间,一共有三个页面,每个页面都有动画效果,动画效果调试起来麻烦,既要跟ios统一,又要匹配各种不同的手机,然后产品经理还有可能在中途改需求 ...

  7. 从零开始编写自己的C#框架(24)——测试

    导航 1.前言 2.不堪回首的开发往事 3.测试推动开发的成长——将Bug消灭在自测中 4.关于软件测试 5.制定测试计划 6.编写测试用例 7.执行测试用例 8.发现并提交Bug 9.开发人员修复B ...

  8. 通过VMware的PowerCLI配置集群内指定主机的vMotion功能

    PowerCLI是VMware开发的基于微软(MSFT)的PowerShell的命令行管理vSphere的实现,因此在批量化操作方面CLI会减轻很多GUI环境下的繁琐重复劳作. 现有场景中有大量的物理 ...

  9. Web安全相关(三):开放重定向(Open Redirection)

    简介 那些通过请求(如查询字符串和表单数据)指定重定向URL的Web程序可能会被篡改,而把用户重定向到外部的恶意URL.这种篡改就被称为开发重定向攻击.   场景分析 假设有一个正规网站http:// ...

  10. SQL 数据优化索引建suo避免全表扫描

    首先什么是全表扫描和索引扫描?全表扫描所有数据过一遍才能显示数据结果,索引扫描就是索引,只需要扫描一部分数据就可以得到结果.如果数据没建立索引. 无索引的情况下搜索数据的速度和占用内存就会比用索引的检 ...