#include "ltdic.h"
L_LTDIC_API L_INT L_DicomSendNGetResponse(hNet, nPresentationID, nMessageID, pszClass, pszInstance, nStatus, hDS)
HDICOMNET hNet; |
a DICOM Network handle |
L_UCHAR nPresentationID; |
presentation ID |
L_UINT16 nMessageID; |
message ID |
L_TCHAR * pszClass; |
class type |
L_TCHAR * pszInstance; |
instance |
L_UINT16 nStatus; |
status |
HDICOMDS hDS; |
data set |
Sends an N-GET-RSP message to a peer member of a connection.
Parameter |
Description |
hNet |
A DICOM Network handle to the peer member of the connection. |
nPresentationID |
Presentation ID. The presentation ID provides information about both the class type of the data and the transfer syntax to use when transferring the data. |
nMessageID |
Message ID. Each message sent by a member of a connection should have a unique ID. Since a member of a connection may send several messages, this ID allows that member to identify when a specific request has been completed. |
pszClass |
Class affected by the request. This will be an SOP Class or an SOP MetaClass. |
pszInstance |
The instance of the class. A server may, for example, have three instances of the Nuclear Medicine Class. This value identifies the data with a specific instance. |
nStatus |
The status of the original request. For a list of possible values, refer to Status Constants. |
hDS |
Data set that contains the retrieved elements. |
DICOM_SUCCESS |
The function was successful. |
>0 |
An error occurred. Refer to Return Codes. |
L_DicomSendNGetResponse is sent by the SCP in response to an L_DicomSendNGetRequest call placed by an SCU. This generates a call to RECEIVENGETRESPONSECALLBACK on the SCU.
Required DLLs and Libraries
|
For a listing of the exact DLLs and Libraries needed, based on the toolkit version, refer to Files To Be Included With Your Application |
Win32, x64, Linux.
Functions: |
L_DicomSendNGetRequest, RECEIVENGETREQUESTCALLBACK, RECEIVENGETRESPONSECALLBACK |
Topics: |
#define MAKE_IMAGE_PATH(pFileName) TEXT("C:\\Users\\Public\\Documents\\LEADTOOLS Images\\")pFileName#include <windowsx.h>static HWND hList; /* handle to list box */L_INT16 PerformNGETCommand(L_TCHAR* pszClass,L_TCHAR* pszInstance,HDICOMDS hDS,L_UINT32* pnAttribute,L_UINT32 nCount){UNREFERENCED_PARAMETER(pszInstance);UNREFERENCED_PARAMETER(pszClass);L_INT16 nRet;L_UINT32 x;HDICOMDS hDSTemp=NULL;pDICOMELEMENT pElement=NULL;pDICOMELEMENT pNewElement=NULL;pDICOMTAG pTag=NULL;L_TCHAR *pVal=NULL;L_UINT32 uSize;L_UINT32 uCount;/*this sample simply loads a fixed data sethere, a server should check the class and instance againstall SOP classes it manages, and then fill out hDS from thecorrectly matching instance, if one is found*/hDSTemp = L_DicomCreateDS(NULL);nRet = L_DicomLoadDS(hDSTemp, MAKE_IMAGE_PATH(TEXT("IMAGE1.dcm")), 0);L_DicomInitDS(hDS, CLASS_UNKNOWN, 0);L_DicomResetDS(hDS);if(nRet != DICOM_SUCCESS){L_DicomFreeDS(hDSTemp);return nRet;}for(x=0; x<nCount; x++){/* get each element */pTag = L_DicomFindTag(pnAttribute[x]);pElement = L_DicomFindFirstElement(hDSTemp, NULL, pnAttribute[x], FALSE);/* in this sample, if we don't find the requested tag, we *//* do not return an empty element! */if(pElement){/* copy the element value */uCount = L_DicomGetCountValue(hDSTemp, pElement);uSize = L_DicomGetConvertValue(hDSTemp, pElement, NULL, 0);pVal = (L_TCHAR *)GlobalAllocPtr(GMEM_MOVEABLE, uSize * sizeof(L_TCHAR));L_DicomGetConvertValue(hDSTemp, pElement, pVal, uSize);pNewElement = L_DicomInsertElement(hDS, NULL, FALSE, pnAttribute[x], pTag->nVR, FALSE, 0);if (pElement == NULL){L_DicomFreeDS(hDS);return DICOM_ERROR_MEMORY;}L_DicomSetConvertValue(hDS, pNewElement, pVal, uCount);GlobalFreePtr(pVal);}}L_DicomFreeDS(hDSTemp);return(DICOM_SUCCESS);}L_VOID EXT_CALLBACK OnReceiveNGetRequest(HDICOMNET hNet, L_UCHAR nPresentationID, L_UINT16 nMessageID, L_TCHAR *pszClass, L_TCHAR *pszInstance, L_UINT32 *pnAttribute, L_UINT32 nCount, L_VOID *pUserData){UNREFERENCED_PARAMETER(pUserData);UNREFERENCED_PARAMETER(pszInstance);UNREFERENCED_PARAMETER(pszClass);L_TCHAR szMsg[800];HDICOMDS hDS=NULL;L_INT nRet;ListBox_AddString(hList, TEXT("Command Set - N-GET-REQUEST"));wsprintf(szMsg, TEXT(" Presentation ID: %d"), nPresentationID);ListBox_AddString(hList, szMsg);wsprintf(szMsg, TEXT(" Message ID: %d"), nMessageID);ListBox_AddString(hList, szMsg);wsprintf(szMsg, TEXT(" Affected SOP Class: %s"), pszClass);ListBox_AddString(hList, szMsg);wsprintf(szMsg, TEXT(" Affected SOP Instance: %s"), pszInstance);ListBox_AddString(hList, szMsg);/* this function will fill the values the data set elements in LEADDICOM2.hDicomDS */hDS = L_DicomCreateDS(NULL);nRet = PerformNGETCommand(pszClass, pszInstance, hDS, pnAttribute, nCount);if(nRet != DICOM_SUCCESS)nRet = COMMAND_STATUS_NO_SUCH_OBJECT_INSTANCE;/* send a response */L_DicomSendNGetResponse(hNet, nPresentationID, nMessageID, pszClass, pszInstance, (L_UINT16) nRet, (nRet==DICOM_SUCCESS)?hDS:0);L_DicomFreeDS(hDS);}