В ExoPlayer, как именно использовать SimpleExoPlayer.setVideoScalingMode, чтобы быть похожим на ImageView по центру? - PullRequest
0 голосов
/ 05 июля 2018

Фон

Я пытаюсь показать видео в центральном кадре (как в ImageView).

Я также надеюсь, что смогу найти способы масштабирования другими способами, как это сделано в этой библиотеке .

Проблема

Я использую это для этой цели:

    player!!.videoScalingMode = C.VIDEO_SCALING_MODE_SCALE_TO_FIT_WITH_CROPPING

Но по какой-то причине он не выполняет обрезку по центру.

Что я пробовал

Глядя на документы, я вижу это:

"Обратите внимание, что режим масштабирования применяется только в том случае, если включен рендерер видео на основе MediaCodec и если поверхность вывода принадлежит SurfaceView."

Итак, я попытался установить это в файле XML:

     app:surface_type="surface_view"

но это тоже не помогло. Я также не вижу его доступным в коде.

Я пытался найти что-нибудь с помощью «рендерера» или «кодека» для этого класса, но ни один не существует.

Вот код, который я использую (на основании этого: https://github.com/yusufcakmak/ExoPlayerSample):

class MainActivity : AppCompatActivity() {
    val VIDEO_URL = "https://www.sample-videos.com/video/mp4/720/big_buck_bunny_720p_1mb.mp4"
    private var player: SimpleExoPlayer? = null

    private var window: Timeline.Window? = null
    private var mediaDataSourceFactory: DataSource.Factory? = null
    private var trackSelector: DefaultTrackSelector? = null
    private var shouldAutoPlay: Boolean = false
    private var bandwidthMeter: BandwidthMeter? = null

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        shouldAutoPlay = true
        bandwidthMeter = DefaultBandwidthMeter()
        mediaDataSourceFactory = DefaultDataSourceFactory(this, Util.getUserAgent(this, "mediaPlayerSample"), bandwidthMeter as TransferListener<in DataSource>)
        window = Timeline.Window()
    }

    private fun initializePlayer() {
        if (player != null)
            return
        simpleExoPlayerView.requestFocus()
        val videoTrackSelectionFactory = AdaptiveTrackSelection.Factory(bandwidthMeter)
        trackSelector = DefaultTrackSelector(videoTrackSelectionFactory)
        player = ExoPlayerFactory.newSimpleInstance(this, trackSelector)
        simpleExoPlayerView.player = player
        player!!.repeatMode = Player.REPEAT_MODE_ALL
        player!!.playWhenReady = shouldAutoPlay
        player!!.videoScalingMode = C.VIDEO_SCALING_MODE_SCALE_TO_FIT_WITH_CROPPING
        val extractorsFactory = DefaultExtractorsFactory()
        val mediaSource = ExtractorMediaSource(Uri.parse(VIDEO_URL), mediaDataSourceFactory, extractorsFactory, null, null)
        player!!.prepare(mediaSource)
    }

    private fun releasePlayer() {
        if (player != null) {
            shouldAutoPlay = player!!.getPlayWhenReady()
            player!!.release()
            player = null
            trackSelector = null
        }
    }

    public override fun onStart() {
        super.onStart()
        if (Util.SDK_INT > 23) {
            initializePlayer()
        }
    }

    public override fun onResume() {
        super.onResume()
        if (Util.SDK_INT <= 23 || player == null) {
            initializePlayer()
        }
    }

    public override fun onPause() {
        super.onPause()
        if (Util.SDK_INT <= 23) {
            releasePlayer()
        }
    }

    public override fun onStop() {
        super.onStop()
        if (Util.SDK_INT > 23) {
            releasePlayer()
        }
    }
}

activity_main.xml

<com.google.android.exoplayer2.ui.SimpleExoPlayerView
    android:id="@+id/simpleExoPlayerView" xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent"
    android:focusable="true" app:surface_type="surface_view"/>

манифест

<uses-permission android:name="android.permission.INTERNET"/>

файл Gradle

implementation 'com.google.android.exoplayer:exoplayer:r2.5.2'

Вопросы

  1. Что не так в том, что я сделал?

  2. Что именно является первым требованием?

  3. Я думаю, что эта версия SDK немного устарела. Как мне его обновить? Может быть, это ошибка, и она исправлена?

1 Ответ

0 голосов
/ 08 июля 2018

ОК, я понял. Пришлось обновить SDK и по какой-то причине использовать библиотеку поддержки вместо версии Android-X.

Существует несколько доступных типов масштабирования, называемых ResizeMode ( здесь ):

  • зум = такой же, как в центре кадрирования
  • fit = такой же, как fit-center
  • fill = такой же, как fit-xy (растяжение, без сохранения соотношения сторон)

Вот код:

MainActivity.kt

class MainActivity : AppCompatActivity() {
    private var player: SimpleExoPlayer? = null

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
    }

    override fun onStart() {
        super.onStart()
        player = ExoPlayerFactory.newSimpleInstance(this, DefaultTrackSelector())
        playerView.player = player
        val dataSourceFactory = DefaultDataSourceFactory(this, getUserAgent(this))
        val mediaSource = ExtractorMediaSource.Factory(dataSourceFactory).createMediaSource(Uri.parse("https://www.sample-videos.com/video/mkv/720/big_buck_bunny_720p_2mb.mkv"))
        player!!.prepare(mediaSource)
        playerView.useController=false
        player!!.playWhenReady = true
        player!!.repeatMode = Player.REPEAT_MODE_ALL
    }

    override fun onStop() {
        super.onStop()
        playerView.player = null
        player!!.release()
        player = null
    }

    fun getUserAgent(context: Context): String {
        val packageName = context.packageName
        val info = context.packageManager.getPackageInfo(packageName, 0)
        val appName = info.applicationInfo.loadLabel(context.packageManager).toString()
        val versionName = info.versionName
        return "$appName/$versionName (Linux;Android ${Build.VERSION.RELEASE}) ${ExoPlayerLibraryInfo.VERSION_SLASHY}"
    }
}

манифест

<uses-permission android:name="android.permission.INTERNET"/>

расположение

<FrameLayout
    xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent" tools:context=".MainActivity">

    <!--zoom=center-crop fit=center-inside fill-stretch-->

    <com.google.android.exoplayer2.ui.PlayerView
        android:id="@+id/playerView" android:layout_width="match_parent" android:layout_height="match_parent"
        app:resize_mode="zoom"/>
</FrameLayout>

Gradle

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation"org.jetbrains.kotlin:kotlin-stdlib-jre7:$kotlin_version"
    implementation 'com.android.support:appcompat-v7:28.0.0-alpha3'
    implementation 'com.android.support.constraint:constraint-layout:1.1.2'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
    implementation 'com.google.android.exoplayer:exoplayer-core:2.8.1'
    implementation 'com.google.android.exoplayer:exoplayer-ui:2.8.1'
}
...