From ddaed22630e384ab342cea7ff85253577bb721bc Mon Sep 17 00:00:00 2001 From: hch <16607480311@163.com> Date: Tue, 2 Apr 2024 10:02:32 +0800 Subject: [PATCH] =?UTF-8?q?fix=20[=E4=BF=AE=E5=A4=8D-=E8=A7=86=E9=A2=91?= =?UTF-8?q?=E6=92=AD=E6=94=BE=E9=97=AE=E9=A2=98]?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../video/views/VideoPlayViewHolder.java | 26 ++++++++---- .../video/views/VideoPlayWrapViewHolder.java | 42 ++++++------------- .../video/views/VideoScrollViewHolder.java | 9 +++- .../main/res/layout/view_video_play_wrap.xml | 6 ++- 4 files changed, 41 insertions(+), 42 deletions(-) diff --git a/video/src/main/java/com/yunbao/video/views/VideoPlayViewHolder.java b/video/src/main/java/com/yunbao/video/views/VideoPlayViewHolder.java index 86669a0..a14cfb8 100644 --- a/video/src/main/java/com/yunbao/video/views/VideoPlayViewHolder.java +++ b/video/src/main/java/com/yunbao/video/views/VideoPlayViewHolder.java @@ -15,6 +15,7 @@ import com.google.android.exoplayer2.PlaybackException; import com.google.android.exoplayer2.Player; import com.google.android.exoplayer2.ui.AspectRatioFrameLayout; import com.google.android.exoplayer2.ui.StyledPlayerView; +import com.google.android.exoplayer2.video.VideoSize; import com.yunbao.common.bean.ActiveBean; import com.yunbao.common.utils.L; import com.yunbao.common.utils.ToastUtil; @@ -57,14 +58,7 @@ public class VideoPlayViewHolder extends AbsViewHolder implements View.OnClickLi } private void intiPlayView() { - DefaultLoadControl control = new DefaultLoadControl.Builder() - .setPrioritizeTimeOverSizeThresholds(false) - .setBackBuffer(10_000, true) - .setBufferDurationsMs(500, - 5_000, - 150, - 200) - .build(); + DefaultLoadControl control = new DefaultLoadControl.Builder().setPrioritizeTimeOverSizeThresholds(false).setBackBuffer(10_000, true).setBufferDurationsMs(500, 5_000, 150, 200).build(); mPlayer = new ExoPlayer.Builder(mContext).setLoadControl(control).build(); placeholderView = findViewById(com.yunbao.live.R.id.placeholderView); mPlayer = new ExoPlayer.Builder(mContext).setLoadControl(control).build(); @@ -87,10 +81,22 @@ public class VideoPlayViewHolder extends AbsViewHolder implements View.OnClickLi case Player.STATE_ENDED://播放器完整播放了所有媒体。 replay(); break; - } } + @Override + public void onVideoSizeChanged(VideoSize videoSize) { + Player.Listener.super.onVideoSizeChanged(videoSize); + if (mActionListener != null) { + mActionListener.onVideoSize(videoSize.height, videoSize.width); + } + } + + @Override + public void onRenderedFirstFrame() { + Player.Listener.super.onRenderedFirstFrame(); + } + @Override public void onPlayerError(PlaybackException error) { Player.Listener.super.onPlayerError(error); @@ -259,6 +265,8 @@ public class VideoPlayViewHolder extends AbsViewHolder implements View.OnClickLi void onFirstFrame(); + void onVideoSize(int height, int width); + void onProgress(int progress, int duration); } diff --git a/video/src/main/java/com/yunbao/video/views/VideoPlayWrapViewHolder.java b/video/src/main/java/com/yunbao/video/views/VideoPlayWrapViewHolder.java index 0d6ffc6..daa73df 100644 --- a/video/src/main/java/com/yunbao/video/views/VideoPlayWrapViewHolder.java +++ b/video/src/main/java/com/yunbao/video/views/VideoPlayWrapViewHolder.java @@ -57,7 +57,7 @@ import java.util.List; public class VideoPlayWrapViewHolder extends AbsViewHolder implements View.OnClickListener { private ViewGroup mVideoContainer; - private MyImageView mCover; + private ImageView mCover; private ImageView mAvatar; private TextView mName; private TextView mTitle; @@ -101,7 +101,7 @@ public class VideoPlayWrapViewHolder extends AbsViewHolder implements View.OnCli progressCount = (TextView) findViewById(R.id.progressCount); mVideoContainer = (ViewGroup) findViewById(R.id.video_container); - mCover = (MyImageView) findViewById(R.id.cover); + mCover = (ImageView) findViewById(R.id.cover); mAvatar = (ImageView) findViewById(R.id.avatar); mName = (TextView) findViewById(R.id.name); mTitle = (TextView) findViewById(R.id.title); @@ -303,20 +303,6 @@ public class VideoPlayWrapViewHolder extends AbsViewHolder implements View.OnCli mCover.requestLayout(); } mCover.setImageDrawable(drawable); - - /* - RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) mCover.getLayoutParams(); - - int imageWidth = drawable.getIntrinsicWidth(); - int imageHeight = drawable.getIntrinsicHeight(); - - //宽度固定,然后根据原始宽高比得到此固定宽度需要的高度 - //screenWidth 是屏幕宽度 - int height = mCover.getWidth() * imageHeight / imageWidth; - ViewGroup.LayoutParams para = mCover.getLayoutParams(); - para.height = height; - para.width = mCover.getWidth();*/ - //mCover.setImageDrawable(drawable); } } @@ -367,6 +353,15 @@ public class VideoPlayWrapViewHolder extends AbsViewHolder implements View.OnCli } } + public void onSetVideoCoverSize(int height, int width) { + if (mCover != null) { + RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) mCover.getLayoutParams(); + params.width = width; + params.height = height; + } + } + + /** * 滑出屏幕 */ @@ -529,20 +524,7 @@ public class VideoPlayWrapViewHolder extends AbsViewHolder implements View.OnCli } else { image = mVideoBean.getVideo() + "?vframe/jpg/offset/0"; } - new SharePopDialog(mContext) - .setShareType(SharePopDialog.TYPE_VIDEO) - .setShareData(ShareBean.ShareBuilder.create() - .setShareType(SharePopDialog.TYPE_VIDEO) - .setUid(CommonAppConfig.getInstance().getUid()) - .setCover(StringUtil.isEmpty(image) ? mVideoBean.getUser_avatar() : image) - .setTitle(StringUtil.isEmpty(mVideoBean.getContent()) ? mVideoBean.getUser_name() : JSONObject.parseObject(mVideoBean.getContent()).getString("msg")) - .setAnchorId(mVideoBean.getUser_id()) - .setAnchorName(mVideoBean.getUser_name()) - .setAnchorAvatar(mVideoBean.getUser_avatar()) - .setExtraData(mVideoBean.getId()) - .build() - ) - .showDialog(); + new SharePopDialog(mContext).setShareType(SharePopDialog.TYPE_VIDEO).setShareData(ShareBean.ShareBuilder.create().setShareType(SharePopDialog.TYPE_VIDEO).setUid(CommonAppConfig.getInstance().getUid()).setCover(StringUtil.isEmpty(image) ? mVideoBean.getUser_avatar() : image).setTitle(StringUtil.isEmpty(mVideoBean.getContent()) ? mVideoBean.getUser_name() : JSONObject.parseObject(mVideoBean.getContent()).getString("msg")).setAnchorId(mVideoBean.getUser_id()).setAnchorName(mVideoBean.getUser_name()).setAnchorAvatar(mVideoBean.getUser_avatar()).setExtraData(mVideoBean.getId()).build()).showDialog(); } public void release() { diff --git a/video/src/main/java/com/yunbao/video/views/VideoScrollViewHolder.java b/video/src/main/java/com/yunbao/video/views/VideoScrollViewHolder.java index b697cf3..60d8010 100644 --- a/video/src/main/java/com/yunbao/video/views/VideoScrollViewHolder.java +++ b/video/src/main/java/com/yunbao/video/views/VideoScrollViewHolder.java @@ -241,6 +241,13 @@ public class VideoScrollViewHolder extends AbsViewHolder implements VideoScrollA } } + @Override + public void onVideoSize(int height, int width) { + if (mVideoPlayWrapViewHolder != null) { + mVideoPlayWrapViewHolder.onSetVideoCoverSize(height, width); + } + } + @Override public void onProgress(int progress, int duration) { if (mVideoPlayWrapViewHolder != null) { @@ -318,7 +325,7 @@ public class VideoScrollViewHolder extends AbsViewHolder implements VideoScrollA */ private void openCommentInputWindow(boolean openFace) { if (mVideoBean != null) { - ((AbsVideoPlayActivity) mContext).openCommentInputWindowNew(openFace, mVideoBean.getId(), mVideoBean.getUser_id(), false,"",Integer.parseInt(mVideoBean.getComment_num())); + ((AbsVideoPlayActivity) mContext).openCommentInputWindowNew(openFace, mVideoBean.getId(), mVideoBean.getUser_id(), false, "", Integer.parseInt(mVideoBean.getComment_num())); } } diff --git a/video/src/main/res/layout/view_video_play_wrap.xml b/video/src/main/res/layout/view_video_play_wrap.xml index 5c6e171..7f55226 100644 --- a/video/src/main/res/layout/view_video_play_wrap.xml +++ b/video/src/main/res/layout/view_video_play_wrap.xml @@ -10,11 +10,13 @@ android:layout_width="match_parent" android:layout_height="match_parent" /> - + android:layout_centerHorizontal="true" + android:layout_centerVertical="true" + android:scaleType="centerCrop" />