本文整理汇总了C#中Microsoft.Protocols.TestTools.StackSdk.PduMarshaler.WriteUInt16方法的典型用法代码示例。如果您正苦于以下问题:C# PduMarshaler.WriteUInt16方法的具体用法?C# PduMarshaler.WriteUInt16怎么用?C# PduMarshaler.WriteUInt16使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Microsoft.Protocols.TestTools.StackSdk.PduMarshaler
的用法示例。
在下文中一共展示了PduMarshaler.WriteUInt16方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Encode
/// <summary>
/// Encode this PDU to the PduMarshaler.
/// </summary>
/// <param name="marshaler">This is used to encode the fields of this PDU.</param>
public override void Encode(PduMarshaler marshaler)
{
base.Encode(marshaler);
marshaler.WriteUInt16(this.surfaceId);
marshaler.WriteUInt64(this.cacheKey);
marshaler.WriteUInt16(this.cacheSlot);
marshaler.WriteUInt16(this.rectSrc.left);
marshaler.WriteUInt16(this.rectSrc.top);
marshaler.WriteUInt16(this.rectSrc.right);
marshaler.WriteUInt16(this.rectSrc.bottom);
}
示例2: Encode
/// <summary>
/// Encode this PDU to the PduMarshaler.
/// </summary>
/// <param name="marshaler">This is used to encode the fields of this PDU.</param>
public override void Encode(PduMarshaler marshaler)
{
marshaler.WriteUInt32(this.Header.cbSize);
marshaler.WriteUInt32((uint)this.Header.PacketType);
marshaler.WriteByte(this.PresentatioinId);
marshaler.WriteByte((byte)this.NotificationType);
marshaler.WriteUInt16(this.Reserved);
marshaler.WriteUInt32(this.cbData);
marshaler.WriteBytes(this.pData);
}
示例3: Encode
/// <summary>
/// Encode this PDU to the PduMarshaler.
/// </summary>
/// <param name="marshaler">This is used to encode the fields of this PDU.</param>
public override void Encode(PduMarshaler marshaler)
{
marshaler.WriteUInt16(maximumPacketSize);
marshaler.WriteUInt16(padding);
marshaler.WriteUInt32(maximumTransferSize);
marshaler.WriteUInt32(pipeFlags);
}
示例4: Encode
/// <summary>
/// Encode this PDU to the PduMarshaler.
/// </summary>
/// <param name="marshaler">This is used to encode the fields of this PDU.</param>
public override void Encode(PduMarshaler marshaler)
{
base.Encode(marshaler);
marshaler.WriteByte(this.tileSize);
marshaler.WriteUInt16(this.numRects);
marshaler.WriteByte(this.numQuant);
marshaler.WriteByte(this.numProgQuant);
marshaler.WriteByte(this.flags);
marshaler.WriteUInt16(this.numTiles);
marshaler.WriteUInt32(this.tileDataSize);
// Encode rects, in normal case, it can't be NULL
if (rects != null)
{
for (int i = 0; i < rects.Count(); i++)
{
byte[] arr = Convert2Bytes(rects[i]);
marshaler.WriteBytes(arr);
}
}
// Encode quantVals, in normal case, it can't be NULL
if (quantVals != null)
{
for (int i = 0; i < quantVals.Count(); i++)
{
byte[] arr = Convert2Bytes(quantVals[i]);
marshaler.WriteBytes(arr);
}
}
if (quantProgVals != null) // progressive encoding enabled
{
for (int i = 0; i < quantProgVals.Count(); i++)
{
byte[] arr;
marshaler.WriteByte(quantProgVals[i].quality);
arr = Convert2Bytes(quantProgVals[i].yQuantValues);
marshaler.WriteBytes(arr);
arr = Convert2Bytes(quantProgVals[i].cbQuantValues);
marshaler.WriteBytes(arr);
arr = Convert2Bytes(quantProgVals[i].crQuantValues);
marshaler.WriteBytes(arr);
}
}
}
示例5: Encode
public override void Encode(PduMarshaler marshaler)
{
marshaler.WriteUInt32(fecHeader.snSourceAck);
marshaler.WriteUInt16(fecHeader.uReceiveWindowSize);
marshaler.WriteUInt16((ushort)fecHeader.uFlags);
if (SynData.HasValue)
{
marshaler.WriteUInt32(SynData.Value.snInitialSequenceNumber);
marshaler.WriteUInt16(SynData.Value.uUpStreamMtu);
marshaler.WriteUInt16(SynData.Value.uDownStreamMtu);
// This datagram MUST be zero-padded to increase the size of this datagram to 1232 bytes.
int length = 16;
if (CorrelationId.HasValue)
{
marshaler.WriteBytes(CorrelationId.Value.uCorrelationId);
length += 16;
marshaler.WriteBytes(CorrelationId.Value.uReserved);
length += 16;
}
byte[] padBytes = new byte[1232 - length];
marshaler.WriteBytes(padBytes);
return;
}
if (ackVectorHeader.HasValue)
{
// ACK
marshaler.WriteUInt16(ackVectorHeader.Value.uAckVectorSize);
if (ackVectorHeader.Value.AckVectorElement != null)
{
List<byte> ackVecElementList = new List<byte>();
foreach (AckVector vec in ackVectorHeader.Value.AckVectorElement)
{
byte vecByte = 0;
vecByte |= vec.Length;
byte state = (byte)vec.State;
vecByte |= (byte)(state << 6);
ackVecElementList.Add(vecByte);
}
ackVecElementList.Reverse();
marshaler.WriteBytes(ackVecElementList.ToArray());
}
// Padding (variable): A variable-sized array, of length zero or more,
// such that this structure ends on a DWORD ([MS-DTYP] section 2.2.9) boundary.
int padLen = 4 - (2 + ackVectorHeader.Value.uAckVectorSize) % 4;
if (padLen > 0 && padLen != 4)
{
byte[] padding = new byte[padLen];
marshaler.WriteBytes(padding);
}
// Ack of Acks.
if (ackOfAckVector.HasValue)
{
marshaler.WriteUInt32(ackOfAckVector.Value.snAckOfAcksSeqNum);
}
}
if (sourceHeader.HasValue || fecPayloadHeader.HasValue)
{
if (sourceHeader.HasValue)
{
// Source Data.
marshaler.WriteUInt32(sourceHeader.Value.snCoded);
marshaler.WriteUInt32(sourceHeader.Value.snSourceStart);
}
else
{
// FEC Data.
marshaler.WriteUInt32(fecPayloadHeader.Value.snCoded);
marshaler.WriteUInt32(fecPayloadHeader.Value.snSourceStart);
marshaler.WriteByte(fecPayloadHeader.Value.uRange);
marshaler.WriteByte(fecPayloadHeader.Value.uFecIndex);
marshaler.WriteUInt16(fecPayloadHeader.Value.uPadding);
}
if (payload != null)
{
marshaler.WriteBytes(payload);
}
}
}