本文整理汇总了C#中ClearCanvas.Dicom.Network.DicomServer.SendNCreateResponse方法的典型用法代码示例。如果您正苦于以下问题:C# DicomServer.SendNCreateResponse方法的具体用法?C# DicomServer.SendNCreateResponse怎么用?C# DicomServer.SendNCreateResponse使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类ClearCanvas.Dicom.Network.DicomServer
的用法示例。
在下文中一共展示了DicomServer.SendNCreateResponse方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: ModalityPerformedProcedureStepIod
void IDicomServerHandler.OnReceiveRequestMessage(DicomServer server, ServerAssociationParameters association, byte presentationID, DicomMessage message)
{
//_sessionDebug.SetAssociationDumpString(association);
//_sessionDebug._request = message.Dump();
#region CEcho request
if (message.CommandField == DicomCommandField.CEchoRequest)
{
server.SendCEchoResponse(presentationID, message.MessageId, DicomStatuses.Success);
Platform.Log(LogLevel.Info, "Received ECHO-RQ message from {0}.", association.CallingAE);
return;
}
#endregion
#region MPPS NCreate Request
if (message.CommandField == DicomCommandField.NCreateRequest)
{
// june -1st-2009 :
// Unlike the "ModalityWorklistIod" class, the 'partially' implemented ModalityPerformedProcedureStepIod class could
// be usefull here.
ModalityPerformedProcedureStepIod mppsIod = new ModalityPerformedProcedureStepIod(message.DataSet);
Platform.Log(LogLevel.Info, "Message Dumped :\n" + message.Dump("", DicomDumpOptions.KeepGroupLengthElements));
// checking message for error and anomalies
bool conform = CheckNCreateDataSetConformance(server, association, presentationID, mppsIod, true);
if (!conform)
{
server.SendNCreateResponse(presentationID, message.MessageId, new DicomMessage(), DicomStatuses.InvalidAttributeValue);
Platform.Log(LogLevel.Error, "Sending Invalid Attributes Response.");
return;
}
// wrong status
if (mppsIod.PerformedProcedureStepInformation.PerformedProcedureStepStatus != ClearCanvas.Dicom.Iod.Modules.PerformedProcedureStepStatus.InProgress)
{
server.SendNCreateResponse(presentationID, message.MessageId, new DicomMessage(), DicomStatuses.InvalidAttributeValue);
Platform.Log(LogLevel.Error, "Recieved N-Create Request with bad status.");
return;
}
// pps already in cache (duplicated step)
string cacheKeyId = message.DataSet[DicomTags.AffectedSopInstanceUid].GetString(0, string.Empty);
bool alreadyCached;
MPPSScp.CacheMppsEntity(association, cacheKeyId, mppsIod, out alreadyCached);
if (alreadyCached)
{
server.SendNCreateResponse(presentationID, message.MessageId, new DicomMessage(), DicomStatuses.DuplicateSOPInstance);
Platform.Log(LogLevel.Error, "Recieved duplicated N-Create Request.");
return;
}
if (!ProcessNCreateRequest(server, presentationID, message))
{
server.SendNCreateResponse(presentationID, message.MessageId, new DicomMessage(), DicomStatuses.ProcessingFailure);
Platform.Log(LogLevel.Error, "Sending Processing due to NCreate request Failure.");
return;
}
server.SendNCreateResponse(presentationID, message.MessageId, new DicomMessage(), DicomStatuses.Success);
return;
}
#endregion
#region MPPS NSet Request
if (message.CommandField == DicomCommandField.NSetRequest)
{
// june -1st-2009 :
// Unlike the "ModalityWorklistIod" class, the ModalityPerformedProcedureStepIod is fully implemented
// we can use it here.
ModalityPerformedProcedureStepIod mppsIod = new ModalityPerformedProcedureStepIod(message.DataSet);
Platform.Log(LogLevel.Info, "Message Dumped :\n" + message.Dump("", DicomDumpOptions.KeepGroupLengthElements));
// check if pps already in cache (duplicated step)
string cacheKeyId = message.DataSet[DicomTags.AffectedSopInstanceUid].GetString(0, string.Empty);
if (!IsMppsEntitycached(association, cacheKeyId))
{
server.SendNCreateResponse(presentationID, message.MessageId, new DicomMessage(), DicomStatuses.NoSuchObjectInstance);
Platform.Log(LogLevel.Error, "Received Unknown NSset SOP.");
return;
}
// status diffrent from in progress
if (mppsIod.PerformedProcedureStepInformation.PerformedProcedureStepStatus == ClearCanvas.Dicom.Iod.Modules.PerformedProcedureStepStatus.InProgress)
{
server.SendNCreateResponse(presentationID, message.MessageId, new DicomMessage(), DicomStatuses.InvalidAttributeValue);
Platform.Log(LogLevel.Error, "Recieved N-Set Request with In Progress status.");
return;
}
// checking the received mppsiod against cached one
ModalityPerformedProcedureStepIod cachedMppsIod = GetCachedMppsIod(association, cacheKeyId);
//assuming cachedMppsIod not null.
bool conform = CheckNSetDataSetConformance(server, association, presentationID, cachedMppsIod, mppsIod, true);
if (!conform)
{
//.........这里部分代码省略.........