本文整理汇总了C#中DicomMessage.ChangeTransferSyntax方法的典型用法代码示例。如果您正苦于以下问题:C# DicomMessage.ChangeTransferSyntax方法的具体用法?C# DicomMessage.ChangeTransferSyntax怎么用?C# DicomMessage.ChangeTransferSyntax使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类DicomMessage
的用法示例。
在下文中一共展示了DicomMessage.ChangeTransferSyntax方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: SendCStoreRequest
/// <summary>
/// Method to send a DICOM C-STORE-RQ message.
/// </summary>
/// <param name="presentationID"></param>
/// <param name="messageID"></param>
/// <param name="priority"></param>
/// <param name="moveAE"></param>
/// <param name="moveMessageID"></param>
/// <param name="message"></param>
/// <param name="overrideParameters"></param>
public void SendCStoreRequest(byte presentationID, ushort messageID,
DicomPriority priority, string moveAE, ushort moveMessageID, DicomMessage message,
DicomCodecParameters overrideParameters)
{
DicomUid affectedClass = _assoc.GetAbstractSyntax(presentationID);
if (!affectedClass.UID.Equals(message.SopClass.Uid))
throw new DicomException(
String.Format(
"SOP Class Uid in the message {0} does not match SOP Class UID for presentation context {1}",
message.SopClass.Uid, affectedClass.UID));
DicomAttributeCollection command = message.MetaInfo;
message.MessageId = messageID;
message.CommandField = DicomCommandField.CStoreRequest;
message.AffectedSopClassUid = message.SopClass.Uid;
message.DataSetType = 0x0202;
message.Priority = priority;
String sopInstanceUid;
bool ok = message.DataSet[DicomTags.SopInstanceUid].TryGetString(0, out sopInstanceUid);
if (!ok)
throw new DicomException("SOP Instance UID unexpectedly not set in CStore Message being sent.");
message.AffectedSopInstanceUid = sopInstanceUid;
if (!string.IsNullOrEmpty(moveAE))
{
message.MoveOriginatorApplicationEntityTitle = moveAE;
message.MoveOriginatorMessageId = moveMessageID;
}
// Handle compress/decompress if necessary
TransferSyntax contextSyntax = _assoc.GetAcceptedTransferSyntax(presentationID);
if ((contextSyntax != message.TransferSyntax)
&& (contextSyntax.Encapsulated || message.TransferSyntax.Encapsulated))
{
if (overrideParameters != null)
message.ChangeTransferSyntax(contextSyntax, null, overrideParameters);
else
message.ChangeTransferSyntax(contextSyntax);
}
SendDimse(presentationID, command, message.DataSet);
}
示例2: SendOnPresentationContext
private void SendOnPresentationContext(DicomClient client, ClientAssociationParameters association, byte pcid, StorageInstance fileToSend, DicomMessage msg)
{
var presContext = association.GetPresentationContext(pcid);
if (msg.TransferSyntax.Encapsulated
&& presContext.AcceptedTransferSyntax.Encapsulated
&& !msg.TransferSyntax.Equals(presContext.AcceptedTransferSyntax))
{
// Compressed in different syntaxes, decompress here first, ChangeTransferSyntax does not convert syntaxes properly in this case.
msg.ChangeTransferSyntax(TransferSyntax.ExplicitVrLittleEndian);
}
fileToSend.SentMessageId = client.NextMessageID();
if (_moveOriginatorAe == null)
client.SendCStoreRequest(pcid, fileToSend.SentMessageId, DicomPriority.Medium, msg);
else
client.SendCStoreRequest(pcid, fileToSend.SentMessageId, DicomPriority.Medium, _moveOriginatorAe,
_moveOriginatorMessageId, msg);
}