Skip to content

Commit

Permalink
screenrecord: get codec capabilities & limit frame rate configuration
Browse files Browse the repository at this point in the history
Screenrecord is using display refresh rate and configuring it as
framerate for any dimensions (width*height) set. But few devices may
not support this fps for given resolution causing encoder config
failure. To avoid such issues, obtain corresponding performance point
value and limit the frame rate, if its less than display refresh rate.

CRs-Fixed: 3602397
Change-Id: I150590d2ce7d458af20a1740efc37efc1eb867be
  • Loading branch information
Malathi Gottam authored and NurKeinNeid committed Apr 1, 2024
1 parent 88ac00b commit cceaa8c
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 1 deletion.
1 change: 1 addition & 0 deletions cmds/screenrecord/Android.bp
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ cc_binary {
"libmedia",
"libmediandk",
"libmedia_omx",
"libmedia_codeclist",
"libutils",
"libbinder",
"libstagefright_foundation",
Expand Down
29 changes: 28 additions & 1 deletion cmds/screenrecord/screenrecord.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -49,16 +49,20 @@
#include <gui/SurfaceComposerClient.h>
#include <gui/ISurfaceComposer.h>
#include <media/MediaCodecBuffer.h>
#include <media/MediaCodecInfo.h>
#include <media/NdkMediaCodec.h>
#include <media/NdkMediaFormatPriv.h>
#include <media/NdkMediaMuxer.h>
#include <media/openmax/OMX_IVCommon.h>
#include <media/stagefright/MediaCodec.h>
#include <media/stagefright/MediaCodecConstants.h>
#include <media/stagefright/MediaCodecList.h>
#include <media/stagefright/MediaCodecListOverrides.h>
#include <media/stagefright/MediaErrors.h>
#include <media/stagefright/PersistentSurface.h>
#include <media/stagefright/foundation/ABuffer.h>
#include <media/stagefright/foundation/AMessage.h>
#include <media/stagefright/foundation/AUtils.h>
#include <mediadrm/ICrypto.h>
#include <ui/DisplayMode.h>
#include <ui/DisplayState.h>
Expand All @@ -75,9 +79,12 @@ using android::ui::DisplayMode;
using android::FrameOutput;
using android::IBinder;
using android::IGraphicBufferProducer;
using android::IMediaCodecList;
using android::ISurfaceComposer;
using android::MediaCodec;
using android::MediaCodecBuffer;
using android::MediaCodecList;
using android::MediaCodecInfo;
using android::Overlay;
using android::PersistentSurface;
using android::PhysicalDisplayId;
Expand Down Expand Up @@ -198,7 +205,6 @@ static status_t prepareEncoder(float displayFps, sp<MediaCodec>* pCodec,
format->setString(KEY_MIME, kMimeTypeAvc);
format->setInt32(KEY_COLOR_FORMAT, OMX_COLOR_FormatAndroidOpaque);
format->setInt32(KEY_BIT_RATE, gBitRate);
format->setFloat(KEY_FRAME_RATE, displayFps);
format->setInt32(KEY_I_FRAME_INTERVAL, 10);
format->setInt32(KEY_MAX_B_FRAMES, gBframes);
if (gBframes > 0) {
Expand Down Expand Up @@ -227,6 +233,27 @@ static status_t prepareEncoder(float displayFps, sp<MediaCodec>* pCodec,
}
}

// set frame-rate based on codec capability
const sp<IMediaCodecList> mcl = MediaCodecList::getInstance();
AString codecName;
codec->getName(&codecName);
ssize_t codecIdx = mcl->findCodecByName(codecName.c_str());
sp<MediaCodecInfo> info = mcl->getCodecInfo(codecIdx);
sp<MediaCodecInfo::Capabilities> capabilities = info->getCapabilitiesFor(kMimeTypeAvc);
const sp<AMessage> &details = capabilities->getDetails();
std::string perfPointKey = "performance-point-" + std::to_string(gVideoWidth) + "x" +
std::to_string(gVideoHeight) + "-range";
AString minPerfPoint, maxPerfPoint;
AString perfPoint;
if (details->findString(perfPointKey.c_str(), &perfPoint)
&& splitString(perfPoint, "-", &minPerfPoint, &maxPerfPoint)) {
int perfPointValue = strtol(maxPerfPoint.c_str(), NULL, 10);
if (perfPointValue < displayFps) {
displayFps = perfPointValue;
}
}
format->setFloat(KEY_FRAME_RATE, displayFps);

err = codec->configure(format, NULL, NULL,
MediaCodec::CONFIGURE_FLAG_ENCODE);
if (err != NO_ERROR) {
Expand Down

0 comments on commit cceaa8c

Please sign in to comment.