LDicomContextGroup::GetFirst

#include "ltdic.h"

static pDICOMCONTEXTGROUP LDicomContextGroup::GetFirst()

Returns a pointer to the first Context Group in the Context Group Table.

Returns

!NULL

Pointer to a DICOMCONTEXTGROUP structure that specifies the first Context Group in the Context Group Table.

NULL

The Context Group Table is empty.

Comments

Use the LDicomContextGroup::Load and LDicomContextGroup::Insert functions to add Context Groups to the Context Group Table.

Along with this function, the following functions can be used to maneuver through the Context Groups in the Context Group Table:

LDicomContextGroup::GetLast

LDicomContextGroup::GetNext

LDicomContextGroup::GetPrev

You can also use the LDicomContextGroup::GetCount and LDicomContextGroup::FindIndex functions to enumerate the Context Groups in the table.

The Coded Concepts of a Context Group can be investigated using the following functions:

LDicomContextGroup::GetFirstCodedConcept

LDicomContextGroup::GetLastCodedConcept

LDicomContextGroup::GetNextCodedConcept

LDicomContextGroup::GetPrevCodedConcept

LDicomContextGroup::GetCountCodedConcept

LDicomContextGroup::FindIndexCodedConcept

Required DLLs and Libraries

LTDIC

For a listing of the exact DLLs and Libraries needed, based on the toolkit version, refer to Files To Be Included With Your Application

See Also

Functions:

LDicomContextGroup::Load, LDicomContextGroup::Insert, LDicomContextGroup::GetLast, LDicomContextGroup::GetNext, LDicomContextGroup::GetPrev, LDicomContextGroup::GetCount, LDicomContextGroup::FindIndex, LDicomContextGroup::Find, LDicomContextGroup::GetFirstCodedConcept, Class Members

Topics:

Working with Context Groups

Example

L_VOID EnumContextGroups()
{
   LDicomContextGroup::Reset ();

   // Load all the Context Groups
   LDicomContextGroup::Load ();

   pDICOMCONTEXTGROUP pGroup; 
   L_CHAR szMsg[256]; 
   L_INT nRet; 

   // Enumerate them (3 possible ways) 
#if 1

   // One possible way to enumerate the Context Groups
   pGroup = LDicomContextGroup::GetFirst();
   while (pGroup) 
   {
      wsprintf(szMsg, "%s\n%s\n\nEnumerate Coded Concepts?", 
               pGroup->pszContextIdentifier, 
               pGroup->pszName); 
      
      nRet = ::MessageBox(NULL, szMsg, "Context Group", MB_YESNOCANCEL); 
      if (nRet == IDYES) 
      {
         // Refer to the example of LDicomContextGroup::GetFirstCodedConcept
         // for the function EnumCodedConcepts
         EnumCodedConcepts(pGroup); 
      }
      else if (nRet == IDCANCEL) 
      {
         break; 
      }

      pGroup = LDicomContextGroup::GetNext(pGroup); 
   }

#elif 0

   // Another way to enumerate the Context Groups
   L_UINT32 uGroupsCount = LDicomContextGroup::GetCount();
   for (L_UINT32 i = 0; i < uGroupsCount; i++)
   {
      pGroup = LDicomContextGroup::FindIndex(i); 

      wsprintf(szMsg, "%s\n%s\n\nEnumerate Coded Concepts?", 
               pGroup->pszContextIdentifier, 
               pGroup->pszName); 
      
      nRet = ::MessageBox(NULL, szMsg, "Context Group", MB_YESNOCANCEL); 
      if (nRet == IDYES) 
      {
         EnumCodedConcepts(pGroup); 
      }
      else if (nRet == IDCANCEL) 
      {
         break; 
      }
   }

#elif 0

   // A third way to enumerate the Context Groups
   pGroup = LDicomContextGroup::GetLast();
   while (pGroup) 
   {
      wsprintf(szMsg, "%s\n%s\n\nEnumerate Coded Concepts?", 
               pGroup->pszContextIdentifier, 
               pGroup->pszName); 
      
      nRet = ::MessageBox(NULL, szMsg, "Context Group", MB_YESNOCANCEL); 
      if (nRet == IDYES) 
      {
         EnumCodedConcepts(pGroup); 
      }
      else if (nRet == IDCANCEL) 
      {
         break; 
      }

      pGroup = LDicomContextGroup::GetPrev(pGroup); 
   }

#endif
}