當前位置: 首頁>>代碼示例>>Java>>正文


Java ByteBuffer.slice方法代碼示例

本文整理匯總了Java中java.nio.ByteBuffer.slice方法的典型用法代碼示例。如果您正苦於以下問題:Java ByteBuffer.slice方法的具體用法?Java ByteBuffer.slice怎麽用?Java ByteBuffer.slice使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.nio.ByteBuffer的用法示例。


在下文中一共展示了ByteBuffer.slice方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: demuxAnnexb

import java.nio.ByteBuffer; //導入方法依賴的package包/類
public SrsFlvFrameBytes demuxAnnexb(ByteBuffer bb, int size, boolean isOnlyChkHeader) {
  SrsFlvFrameBytes tbb = new SrsFlvFrameBytes();
  if (bb.position() < size - 4) {
    // each frame must prefixed by annexb format.
    // about annexb, @see H.264-AVC-ISO_IEC_14496-10.pdf, page 211.
    SrsAnnexbSearch tbbsc =
        isOnlyChkHeader ? searchStartcode(bb, size) : searchAnnexb(bb, size);
    // tbbsc.nb_start_code always 4 , after 00 00 00 01
    if (!tbbsc.match || tbbsc.nb_start_code < 3) {
      Log.e(TAG, "annexb not match.");
    } else {
      // the start codes.
      for (int i = 0; i < tbbsc.nb_start_code; i++) {
        bb.get();
      }

      // find out the frame size.
      tbb.data = bb.slice();
      tbb.size = size - bb.position();
    }
  }
  return tbb;
}
 
開發者ID:pedroSG94,項目名稱:rtmp-rtsp-stream-client-java,代碼行數:24,代碼來源:SrsFlvMuxer.java

示例2: allocate

import java.nio.ByteBuffer; //導入方法依賴的package包/類
/** Allocates an empty I420Buffer suitable for an image of the given dimensions. */
public static JavaI420Buffer allocate(int width, int height) {
  int chromaHeight = (height + 1) / 2;
  int strideUV = (width + 1) / 2;
  int yPos = 0;
  int uPos = yPos + width * height;
  int vPos = uPos + strideUV * chromaHeight;

  ByteBuffer buffer = ByteBuffer.allocateDirect(width * height + 2 * strideUV * chromaHeight);

  buffer.position(yPos);
  buffer.limit(uPos);
  ByteBuffer dataY = buffer.slice();

  buffer.position(uPos);
  buffer.limit(vPos);
  ByteBuffer dataU = buffer.slice();

  buffer.position(vPos);
  buffer.limit(vPos + strideUV * chromaHeight);
  ByteBuffer dataV = buffer.slice();

  return new JavaI420Buffer(
      width, height, dataY, width, dataU, strideUV, dataV, strideUV, null /* releaseCallback */);
}
 
開發者ID:Piasy,項目名稱:AppRTC-Android,代碼行數:26,代碼來源:JavaI420Buffer.java

示例3: create

import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
 * Creates a new dex from the contents of {@code bytes}. This API supports
 * both {@code .dex} and {@code .odex} input. Calling this constructor
 * transfers ownership of {@code bytes} to the returned Dex: it is an error
 * to access the buffer after calling this method.
 */
public static Dex create(ByteBuffer data) throws IOException {
    data.order(ByteOrder.LITTLE_ENDIAN);

    // if it's an .odex file, set position and limit to the .dex section
    if (data.get(0) == 'd' && data.get(1) == 'e' && data.get(2) == 'y' && data.get(3) == '\n') {
        data.position(8);
        int offset = data.getInt();
        int length = data.getInt();
        data.position(offset);
        data.limit(offset + length);
        data = data.slice();
    }

    return new Dex(data);
}
 
開發者ID:alibaba,項目名稱:atlas,代碼行數:22,代碼來源:Dex.java

示例4: Mp4MeanBox

import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
 * @param header     parentHeader info
 * @param dataBuffer data of box (doesnt include parentHeader data)
 */
public Mp4MeanBox(Mp4BoxHeader header, ByteBuffer dataBuffer) {
    this.header = header;

    //Double check
    if (!header.getId().equals(IDENTIFIER)) {
        throw new RuntimeException("Unable to process data box because identifier is:" + header.getId());
    }

    //Make slice so operations here don't effect position of main buffer
    this.dataBuffer = dataBuffer.slice();

    //issuer
    this.issuer = Utils.getString(this.dataBuffer, PRE_DATA_LENGTH, header.getDataLength() - PRE_DATA_LENGTH, header.getEncoding());

}
 
開發者ID:openaudible,項目名稱:openaudible,代碼行數:20,代碼來源:Mp4MeanBox.java

示例5: Mp4MeanBox

import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
 * @param header     parentHeader info
 * @param dataBuffer data of box (doesnt include parentHeader data)
 */
public Mp4MeanBox(Mp4BoxHeader header, ByteBuffer dataBuffer)
{
    this.header = header;

    //Double check
    if (!header.getId().equals(IDENTIFIER))
    {
        throw new RuntimeException("Unable to process data box because identifier is:" + header.getId());
    }

    //Make slice so operations here don't effect position of main buffer
    this.dataBuffer = dataBuffer.slice();

    //issuer
    this.issuer = Utils.getString(this.dataBuffer, PRE_DATA_LENGTH, header.getDataLength() - PRE_DATA_LENGTH, header.getEncoding());

}
 
開發者ID:GlennioTech,項目名稱:MetadataEditor,代碼行數:22,代碼來源:Mp4MeanBox.java

示例6: getFirstKeyInBlock

import java.nio.ByteBuffer; //導入方法依賴的package包/類
@Override
public ByteBuffer getFirstKeyInBlock(ByteBuffer block) {
  int keyLength = block.getInt(Bytes.SIZEOF_INT);
  ByteBuffer dup = block.duplicate();
  int pos = 3 * Bytes.SIZEOF_INT;
  dup.position(pos);
  dup.limit(pos + keyLength);
  return dup.slice();
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:10,代碼來源:CopyKeyDataBlockEncoder.java

示例7: moveBufferToChunks

import java.nio.ByteBuffer; //導入方法依賴的package包/類
private void moveBufferToChunks() {
  final ByteBuffer oldBuffer = this.buffer;
  if (this.chunks == null) {
    this.chunks = new LinkedList<ByteBuffer>();
  }
  if (oldBuffer.position() == 0) {
    // if position is zero then nothing has been written (yet) to buffer so no need to move it to
    // chunks
    return;
  }
  oldBuffer.flip();
  this.size += oldBuffer.remaining();
  ByteBuffer bufToAdd = oldBuffer.slice();
  this.chunks.add(bufToAdd);
  int newPos = oldBuffer.limit();
  if ((oldBuffer.capacity() - newPos) <= 0) {
    this.buffer = ByteBuffer.allocate(MIN_CHUNK_SIZE);
  } else {
    oldBuffer.limit(oldBuffer.capacity());
    oldBuffer.position(newPos);
    this.buffer = oldBuffer.slice();
  }
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:24,代碼來源:HeapDataOutputStream.java

示例8: read

import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
 * {@inheritDoc}
 */
@Override
public void read(ByteBuffer byteBuffer) throws TagException {
    int size;
    if (!seek(byteBuffer)) {
        throw new TagNotFoundException("ID3v2.20 tag not found");
    }
    logger.config(getLoggingFilename() + ":" + "Reading tag from file");

    //Read the flags
    readHeaderFlags(byteBuffer);

    // Read the size
    size = ID3SyncSafeInteger.bufferToValue(byteBuffer);

    //Slice Buffer, so position markers tally with size (i.e do not include tagheader)
    ByteBuffer bufferWithoutHeader = byteBuffer.slice();

    //We need to synchronize the buffer
    if (unsynchronization) {
        bufferWithoutHeader = ID3Unsynchronization.synchronize(bufferWithoutHeader);
    }
    readFrames(bufferWithoutHeader, size);
    logger.config(getLoggingFilename() + ":" + "Loaded Frames,there are:" + frameMap.keySet().size());
}
 
開發者ID:openaudible,項目名稱:openaudible,代碼行數:28,代碼來源:ID3v22Tag.java

示例9: selectMappedBuffer

import java.nio.ByteBuffer; //導入方法依賴的package包/類
public SelectMappedBufferResult selectMappedBuffer(int pos, int size) {
    int readPosition = getReadPosition();
    if ((pos + size) <= readPosition) {

        if (this.hold()) {
            ByteBuffer byteBuffer = this.mappedByteBuffer.slice();
            byteBuffer.position(pos);
            ByteBuffer byteBufferNew = byteBuffer.slice();
            byteBufferNew.limit(size);
            return new SelectMappedBufferResult(this.fileFromOffset + pos, byteBufferNew, size, this);
        } else {
            log.warn("matched, but hold failed, request pos: " + pos + ", fileFromOffset: "
                + this.fileFromOffset);
        }
    } else {
        log.warn("selectMappedBuffer request pos invalid, request pos: " + pos + ", size: " + size
            + ", fileFromOffset: " + this.fileFromOffset);
    }

    return null;
}
 
開發者ID:lirenzuo,項目名稱:rocketmq-rocketmq-all-4.1.0-incubating,代碼行數:22,代碼來源:MappedFile.java

示例10: isVbriFrame

import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
 * IS this a VBRI frame
 *
 * @param bb
 * @param mpegFrameHeader
 * @return raw header if this is a VBRI frame
 */
public static ByteBuffer isVbriFrame(ByteBuffer bb, MPEGFrameHeader mpegFrameHeader) {

    //We store this so can return here after scanning through buffer
    int startPosition = bb.position();
    MP3File.logger.finest("Checking VBRI Frame at" + startPosition);

    bb.position(startPosition + VBRI_OFFSET);

    //Create header from here
    ByteBuffer header = bb.slice();

    // Return Buffer to start Point
    bb.position(startPosition);

    //Check Identifier
    byte[] identifier = new byte[VBRI_IDENTIFIER_BUFFER_SIZE];
    header.get(identifier);
    if ((!Arrays.equals(identifier, VBRI_VBR_ID))) {
        return null;
    }
    MP3File.logger.finest("Found VBRI Frame");
    return header;
}
 
開發者ID:openaudible,項目名稱:openaudible,代碼行數:31,代碼來源:VbriFrame.java

示例11: nextByteBuffer

import java.nio.ByteBuffer; //導入方法依賴的package包/類
private static ByteBuffer nextByteBuffer(int size)
{
    ByteBuffer bytebuffer = bigBuffer;
    int i = bytebuffer.limit();
    bytebuffer.position(i).limit(i + size);
    return bytebuffer.slice();
}
 
開發者ID:sudofox,項目名稱:Backmemed,代碼行數:8,代碼來源:Shaders.java

示例12: read

import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
 * {@inheritDoc}
 */
@Override
public void read(ByteBuffer buffer) throws TagException
{
    int size;
    if (!seek(buffer))
    {
        throw new TagNotFoundException(getIdentifier() + " tag not found");
    }
    logger.config(getLoggingFilename() + ":" + "Reading ID3v23 tag");

    readHeaderFlags(buffer);

    // Read the size, this is size of tag not including the tag header
    size = ID3SyncSafeInteger.bufferToValue(buffer);
    logger.config(ErrorMessage.ID_TAG_SIZE.getMsg(getLoggingFilename(),size));

    //Extended Header
    if (extended)
    {
        readExtendedHeader(buffer, size);
    }

    //Slice Buffer, so position markers tally with size (i.e do not include tagHeader)
    ByteBuffer bufferWithoutHeader = buffer.slice();
    //We need to synchronize the buffer
    if (isUnsynchronization())
    {
        bufferWithoutHeader = ID3Unsynchronization.synchronize(bufferWithoutHeader);
    }

    readFrames(bufferWithoutHeader, size);
    logger.config(getLoggingFilename() + ":Loaded Frames,there are:" + frameMap.keySet().size());

}
 
開發者ID:GlennioTech,項目名稱:MetadataEditor,代碼行數:38,代碼來源:ID3v23Tag.java

示例13: sliceFromTo

import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
 * Returns new byte buffer whose content is a shared subsequence of this buffer's content
 * between the specified start (inclusive) and end (exclusive) positions. As opposed to
 * {@link ByteBuffer#slice()}, the returned buffer's byte order is the same as the source
 * buffer's byte order.
 */
private static ByteBuffer sliceFromTo(final ByteBuffer source, final int start, final int end) {
    if (start < 0) {
        throw new IllegalArgumentException("start: " + start);
    }
    if (end < start) {
        throw new IllegalArgumentException("end < start: " + end + " < " + start);
    }
    final int capacity = source.capacity();
    if (end > source.capacity()) {
        throw new IllegalArgumentException("end > capacity: " + end + " > " + capacity);
    }
    final int originalLimit = source.limit();
    final int originalPosition = source.position();
    try {
        source.position(0);
        source.limit(end);
        source.position(start);
        final ByteBuffer result = source.slice();
        result.order(source.order());
        return result;
    } finally {
        source.position(0);
        source.limit(originalLimit);
        source.position(originalPosition);
    }
}
 
開發者ID:Meituan-Dianping,項目名稱:walle,代碼行數:33,代碼來源:ApkUtil.java

示例14: _parseDetails

import java.nio.ByteBuffer; //導入方法依賴的package包/類
@Override
protected void _parseDetails(ByteBuffer content) {
    parseVersionAndFlags(content);
    if (this.getVersion() != 1) {
        throw new RuntimeException("SampleGroupDescriptionBox are only supported in version 1");
    }
    groupingType = IsoTypeReader.read4cc(content);
    if (this.getVersion() == 1) {
        defaultLength = l2i(IsoTypeReader.readUInt32(content));
    }
    long entryCount = IsoTypeReader.readUInt32(content);
    while (entryCount-- > 0) {
        int length = defaultLength;
        if (this.getVersion() == 1) {
            if (defaultLength == 0) {
                descriptionLength = l2i(IsoTypeReader.readUInt32(content));
                length = descriptionLength;
            }
        } else {
            throw new RuntimeException("This should be implemented");
        }
        int finalPos = content.position() + length;
        ByteBuffer parseMe = content.slice();
        parseMe.limit(length);
        groupEntries.add(parseGroupEntry(parseMe, groupingType));
        content.position(finalPos);
    }

}
 
開發者ID:lisnstatic,項目名稱:live_master,代碼行數:30,代碼來源:SampleGroupDescriptionBox.java

示例15: cloneBuffer

import java.nio.ByteBuffer; //導入方法依賴的package包/類
private static ByteBuffer cloneBuffer(final ByteBuffer original, final int begin, final int end) {
    final ByteBuffer clone = ByteBuffer.allocateDirect(original.capacity());
    original.rewind();//copy from the beginning
    clone.put(original);
    original.rewind();
    clone.flip();
    clone.position(begin);
    clone.limit(end);
    return clone.slice();
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:11,代碼來源:NativeArrayBuffer.java


注:本文中的java.nio.ByteBuffer.slice方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。