#include "ltdic.h"
L_LTDIC_API L_INT L_DicomSendCStoreResponse(hNet, nPresentationID, nMessageID, pszClass, pszInstance, nStatus)
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 |
Sends a C-STORE-RSP message to a peer member of a connection. This function is available in the PACS Imaging Toolkit.
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. |
DICOM_SUCCESS |
The function was successful. |
>0 |
An error occurred. Refer to Return Codes. |
L_DicomSendCStoreResponse is sent by the SCP in response to an L_DicomSendCStoreRequest call placed by an SCU. This generates a call to RECEIVECSTORERESPONSECALLBACK 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_DicomSendCStoreRequest, RECEIVECSTOREREQUESTCALLBACK, RECEIVECSTORERESPONSECALLBACK |
Topics: |
|
|
#include <windowsx.h>
static HWND hList; /* handle to list box */
L_INT16 PerformSTORECommand(L_TCHAR * pszClass, L_TCHAR * pszInstance, HDICOMDS hDS)
{
UNREFERENCED_PARAMETER(pszClass);
UNREFERENCED_PARAMETER(pszInstance);
UNREFERENCED_PARAMETER(hDS);
//
// Add your code here
//
return DICOM_SUCCESS;
}
L_VOID EXT_CALLBACK OnReceiveCStoreRequest(HDICOMNET hNet, L_UCHAR nPresentationID, L_UINT16 nMessageID, L_TCHAR *pszClass, L_TCHAR *pszInstance, L_UINT16 nPriority, L_TCHAR *pszMoveAE, L_UINT16 nMoveMessageID, HDICOMDS hDS, L_VOID *pUserData)
{
UNREFERENCED_PARAMETER(pUserData);
UNREFERENCED_PARAMETER(nMoveMessageID);
UNREFERENCED_PARAMETER(pszMoveAE);
UNREFERENCED_PARAMETER(nPriority);
L_INT16 nRet;
L_TCHAR szReply[800];
L_TCHAR szMsg[800];
ListBox_AddString(hList, TEXT("Command Set - C-STORE-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 is a function that you have to write */
nRet = PerformSTORECommand(pszClass, pszInstance, hDS);
if(nRet != DICOM_SUCCESS)
nRet = COMMAND_STATUS_NO_SUCH_OBJECT_INSTANCE;
/* send a response */
lstrcpy(szReply, TEXT("Store Response Command Set Sent - "));
nRet = (L_INT16) L_DicomSendCStoreResponse(hNet, nPresentationID, nMessageID, pszClass, pszInstance, nRet);
if (nRet != DICOM_SUCCESS)
MessageBox(NULL, TEXT("Error Inside Callback Function"), TEXT("OnReceiveCStoreRequest"), MB_OK);
ListBox_AddString(hList, szReply);
}
Raster .NET | C API | C++ Class Library | JavaScript HTML5
Document .NET | C API | C++ Class Library | JavaScript HTML5
Medical .NET | C API | C++ Class Library | JavaScript HTML5
Medical Web Viewer .NET