자원 캘린더와 함께 작업하십시오
Contents
[
Hide
Show
]Resource 클래스는 자원의 캘린더를 설정하거나 얻는 데 사용되는 캘린더 속성을 노출시킵니다. 이 속성은 Aspose.Tasks .calendar 객체를 수락하고 반환합니다.
자원 캘린더 작업
Microsoft Project의 리소스에 대한 캘린더 정의 :
- 자원 시트에서 원하는 리소스를 두 번 클릭하십시오.
- 작업 시간 변경 버튼을 클릭하십시오.
Aspose.Tasks를 사용하여 리소스 캘린더 설정
다음 코드 예제는 표준 캘린더 및 리소스를 생성 한 다음 캘린더를 리소스에 할당합니다.
1// Create project instance and add resource
2System::SharedPtr<Project> project = System::MakeObject<Project>();
3System::SharedPtr<Resource> res = project->get_Resources()->Add(u"Resource1");
4
5// Add standard calendar and assign to resource
6System::SharedPtr<Aspose::Tasks::Calendar> cal = project->get_Calendars()->Add(u"Resource1");
7res->Set<System::SharedPtr<Calendar>>(Rsc::Calendar(), cal);
**Getting Resource Calendar using Aspose.Tasks **
The code example given below demonstrates how to get resource calendars by traversing a project’s resources.
1// Create project instance
2System::SharedPtr<Project> project1 = System::MakeObject<Project>(dataDir + u"ResourceCalendar.mpp");
3
4// Display base calendar name for all resources
5
6{
7 auto res_enumerator = (project1->get_Resources())->GetEnumerator();
8 decltype(res_enumerator->get_Current()) res;
9 while (res_enumerator->MoveNext() && (res = res_enumerator->get_Current(), true))
10 {
11 if (res->Get<System::String>(Rsc::Name()) != nullptr)
12 {
13 System::Console::WriteLine(res->Get<System::SharedPtr<Calendar>>(Rsc::Calendar())->get_BaseCalendar()->get_Name());
14 }
15 }
16}