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


Java MediaCodecInfo.VideoCapabilities方法代碼示例

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


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

示例1: initialize

import android.media.MediaCodecInfo; //導入方法依賴的package包/類
/**
 * Initialize HeifReader module.
 *
 * @param context Context.
 */
public static void initialize(Context context) {
    mRenderScript = RenderScript.create(context);
    mCacheDir = context.getCacheDir();

    // find best HEVC decoder
    mDecoderName = null;
    mDecoderSupportedSize = new Size(0, 0);
    int numCodecs = MediaCodecList.getCodecCount();
    for (int i = 0; i < numCodecs; i++) {
        MediaCodecInfo codecInfo = MediaCodecList.getCodecInfoAt(i);
        if (codecInfo.isEncoder()) {
            continue;
        }
        for (String type : codecInfo.getSupportedTypes()) {
            if (type.equalsIgnoreCase(MediaFormat.MIMETYPE_VIDEO_HEVC)) {
                MediaCodecInfo.CodecCapabilities cap = codecInfo.getCapabilitiesForType(MediaFormat.MIMETYPE_VIDEO_HEVC);
                MediaCodecInfo.VideoCapabilities vcap = cap.getVideoCapabilities();
                Size supportedSize = new Size(vcap.getSupportedWidths().getUpper(), vcap.getSupportedHeights().getUpper());
                Log.d(TAG, "HEVC decoder=\"" + codecInfo.getName() + "\""
                        + " supported-size=" + supportedSize
                        + " color-formats=" + Arrays.toString(cap.colorFormats)
                );
                if (mDecoderSupportedSize.getWidth() * mDecoderSupportedSize.getHeight() < supportedSize.getWidth() * supportedSize.getHeight()) {
                    mDecoderName = codecInfo.getName();
                    mDecoderSupportedSize = supportedSize;
                }
            }
        }
    }
    if (mDecoderName == null) {
        throw new RuntimeException("no HEVC decoding support");
    }
    Log.i(TAG, "HEVC decoder=\"" + mDecoderName + "\" supported-size=" + mDecoderSupportedSize);
}
 
開發者ID:yohhoy,項目名稱:heifreader,代碼行數:40,代碼來源:HeifReader.java

示例2: getEncodVieoeCapability

import android.media.MediaCodecInfo; //導入方法依賴的package包/類
public static EncodeVideoCapability getEncodVieoeCapability(MediaCodec mediaCodec, String mime)
    {
        if( mediaCodec == null || Build.VERSION.SDK_INT < 18) {
            return null;
        }

        EncodeVideoCapability retCapability = new EncodeVideoCapability();
        //String mime = mEncodeFormat.getValue();
        MediaCodecInfo codecInfo = mediaCodec.getCodecInfo();
        MediaCodecInfo.CodecCapabilities capabilities = codecInfo.getCapabilitiesForType(mime);
        int[] deviceColor = capabilities.colorFormats;
        retCapability.colorFormat = deviceColor;
        MediaCodecInfo.CodecProfileLevel[] profileLevels = capabilities.profileLevels;

        if(null != profileLevels)
        {
            retCapability.profileLevel = new EncodeVideoCapability.ProfileLevel[profileLevels.length];
            for(int i = 0; i < profileLevels.length; ++i)
            {
                retCapability.profileLevel[i] = new EncodeVideoCapability.ProfileLevel(profileLevels[i].profile, profileLevels[i].level);
            }
        }


        Range<Integer> widthRange = null;
        Range<Integer> heightRange = null;
        if(Build.VERSION.SDK_INT >= 21) {
                MediaCodecInfo.VideoCapabilities videoCapabilities = capabilities.getVideoCapabilities();
                heightRange = videoCapabilities.getSupportedHeights();
                widthRange = videoCapabilities.getSupportedWidths();

                retCapability.heightAlignment = videoCapabilities.getHeightAlignment();
                retCapability.widthAlignment  = videoCapabilities.getWidthAlignment();
        }
        else //for old device limite max width / height
        {
//            retCapability.widthUpper = 1280;
//            retCapability.widthLower = 176;
//            retCapability.heightUpper = 720;
//            retCapability.heightLower = 144;

            retCapability.heightAlignment = 2;
            retCapability.widthAlignment = 2;
        }

        if(null != widthRange)
        {
            retCapability.widthUpper = widthRange.getUpper();
            retCapability.widthLower = widthRange.getLower();
        }

        if(null != heightRange)
        {
            retCapability.heightUpper = heightRange.getUpper();
            retCapability.heightLower = heightRange.getLower();
        }

        return retCapability;
    }
 
開發者ID:lzmlsfe,項目名稱:19porn,代碼行數:60,代碼來源:EncodeUtils.java

示例3: getVideoCapabilitiesV21

import android.media.MediaCodecInfo; //導入方法依賴的package包/類
@TargetApi(21)
private static MediaCodecInfo.VideoCapabilities getVideoCapabilitiesV21(String mimeType,
    boolean secure) throws DecoderQueryException {
  DecoderInfo decoderInfo = getDecoderInfo(mimeType, secure);
  return decoderInfo == null ? null : decoderInfo.capabilities.getVideoCapabilities();
}
 
開發者ID:MLNO,項目名稱:airgram,代碼行數:7,代碼來源:MediaCodecUtil.java

示例4: isSizeSupportedV21

import android.media.MediaCodecInfo; //導入方法依賴的package包/類
/**
 * Tests whether the device advertises it can decode video of a given type at a specified width
 * and height.
 * <p>
 * Must not be called if the device SDK version is less than 21.
 *
 * @param mimeType The mime type.
 * @param secure Whether the decoder is required to support secure decryption. Always pass false
 *     unless secure decryption really is required.
 * @param width Width in pixels.
 * @param height Height in pixels.
 * @return Whether the decoder advertises support of the given size.
 */
@TargetApi(21)
public static boolean isSizeSupportedV21(String mimeType, boolean secure, int width,
    int height) throws DecoderQueryException {
  Assertions.checkState(Util.SDK_INT >= 21);
  MediaCodecInfo.VideoCapabilities videoCapabilities = getVideoCapabilitiesV21(mimeType, secure);
  return videoCapabilities != null && videoCapabilities.isSizeSupported(width, height);
}
 
開發者ID:MLNO,項目名稱:airgram,代碼行數:21,代碼來源:MediaCodecUtil.java

示例5: isSizeAndRateSupportedV21

import android.media.MediaCodecInfo; //導入方法依賴的package包/類
/**
 * Tests whether the device advertises it can decode video of a given type at a specified
 * width, height, and frame rate.
 * <p>
 * Must not be called if the device SDK version is less than 21.
 *
 * @param mimeType The mime type.
 * @param secure Whether the decoder is required to support secure decryption. Always pass false
 *     unless secure decryption really is required.
 * @param width Width in pixels.
 * @param height Height in pixels.
 * @param frameRate Frame rate in frames per second.
 * @return Whether the decoder advertises support of the given size and frame rate.
 */
@TargetApi(21)
public static boolean isSizeAndRateSupportedV21(String mimeType, boolean secure,
    int width, int height, double frameRate) throws DecoderQueryException {
  Assertions.checkState(Util.SDK_INT >= 21);
  MediaCodecInfo.VideoCapabilities videoCapabilities = getVideoCapabilitiesV21(mimeType, secure);
  return videoCapabilities != null
      && videoCapabilities.areSizeAndRateSupported(width, height, frameRate);
}
 
開發者ID:MLNO,項目名稱:airgram,代碼行數:23,代碼來源:MediaCodecUtil.java


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