From 10ea7d9735e49a5855899f6115392fbf9ca3b5ac Mon Sep 17 00:00:00 2001 From: hch <16607480311@163.com> Date: Mon, 1 Apr 2024 10:46:33 +0800 Subject: [PATCH] =?UTF-8?q?fix=20[=E4=BF=AE=E5=A4=8D-=E8=A7=86=E9=A2=91?= =?UTF-8?q?=E9=97=AE=E9=A2=98]?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../com/yunbao/common/utils/RouteUtil.java | 10 + .../res/layout/item_comment_video_view.xml | 14 +- main/src/main/res/layout/view_homemain.xml | 4 +- video/src/main/AndroidManifest.xml | 7 + .../video/activity/VideoPlayNewActivity.java | 176 ++++++++++++++++++ .../video/views/VideoCommentViewHolder.java | 4 - .../video/views/VideoPlayViewHolder.java | 22 ++- 7 files changed, 221 insertions(+), 16 deletions(-) create mode 100644 video/src/main/java/com/yunbao/video/activity/VideoPlayNewActivity.java diff --git a/common/src/main/java/com/yunbao/common/utils/RouteUtil.java b/common/src/main/java/com/yunbao/common/utils/RouteUtil.java index 331ba4f..e97a37b 100644 --- a/common/src/main/java/com/yunbao/common/utils/RouteUtil.java +++ b/common/src/main/java/com/yunbao/common/utils/RouteUtil.java @@ -57,6 +57,15 @@ public class RouteUtil { public static final String PATH_USER_HOME = "/main/UserHomeActivity"; public static final String PATH_VIDEO_PLAY = "/video/VideoPlayActivity"; + public static final String PATH_VIDEO_NEW_PLAY = "/video/VideoPlayNewActivity"; + + /* public static void forwardVideoPlayActivity(ActiveBean bean) { + ARouter.getInstance().build(PATH_VIDEO_PLAY) + .withParcelable("ActiveBean", bean) + .withString(Constants.VIDEO_KEY, Constants.VIDEO_SINGLE) + .navigation(); + }*/ + public static void forwardUserHome(String uid) { ARouter.getInstance().build(PATH_USER_HOME) .withString(Constants.TO_UID, uid) @@ -408,4 +417,5 @@ public class RouteUtil { .withString(Constants.VIDEO_KEY, Constants.VIDEO_SINGLE) .navigation(); } + } diff --git a/common/src/main/res/layout/item_comment_video_view.xml b/common/src/main/res/layout/item_comment_video_view.xml index c8b5343..d0b1515 100644 --- a/common/src/main/res/layout/item_comment_video_view.xml +++ b/common/src/main/res/layout/item_comment_video_view.xml @@ -4,9 +4,12 @@ xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="wrap_content" + android:layout_marginLeft="10dp" + android:layout_marginTop="10dp" + android:layout_marginRight="10dp" android:background="@drawable/bg_item_comment" android:orientation="vertical" - android:paddingLeft="20dp" + android:paddingLeft="10dp" android:paddingRight="10dp" tools:ignore="MissingDefaultResource"> @@ -14,12 +17,13 @@ android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="10dp" + android:layout_marginBottom="10dp" android:orientation="horizontal"> @@ -73,7 +77,6 @@ android:id="@+id/del" android:layout_width="wrap_content" android:layout_height="wrap_content" - android:layout_marginTop="10dp" android:padding="10dp" android:text="@string/delete" android:textColor="#777777" @@ -84,7 +87,6 @@ android:id="@+id/replyTextView" android:layout_width="wrap_content" android:layout_height="wrap_content" - android:layout_marginTop="10dp" android:padding="10dp" android:text="@string/reply" android:textColor="#777777" @@ -94,7 +96,6 @@ android:id="@+id/report" android:layout_width="wrap_content" android:layout_height="wrap_content" - android:layout_marginTop="10dp" android:layout_marginRight="5dp" android:padding="10dp" android:text="@string/report" @@ -109,7 +110,6 @@ android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginLeft="50dp" - android:layout_marginTop="10dp" android:layout_marginRight="10dp" android:background="@drawable/bg_item_comment" android:orientation="vertical" diff --git a/main/src/main/res/layout/view_homemain.xml b/main/src/main/res/layout/view_homemain.xml index 89fbd4e..ad5b6d7 100644 --- a/main/src/main/res/layout/view_homemain.xml +++ b/main/src/main/res/layout/view_homemain.xml @@ -15,7 +15,7 @@ @@ -30,7 +30,7 @@ diff --git a/video/src/main/AndroidManifest.xml b/video/src/main/AndroidManifest.xml index 7f566ad..a1efabc 100644 --- a/video/src/main/AndroidManifest.xml +++ b/video/src/main/AndroidManifest.xml @@ -10,6 +10,11 @@ android:screenOrientation="portrait" android:windowSoftInputMode="adjustNothing|stateAlwaysHidden" /> + diff --git a/video/src/main/java/com/yunbao/video/activity/VideoPlayNewActivity.java b/video/src/main/java/com/yunbao/video/activity/VideoPlayNewActivity.java new file mode 100644 index 0000000..f3832d2 --- /dev/null +++ b/video/src/main/java/com/yunbao/video/activity/VideoPlayNewActivity.java @@ -0,0 +1,176 @@ +package com.yunbao.video.activity; + +import android.annotation.SuppressLint; +import android.content.Context; +import android.content.Intent; +import android.text.TextUtils; +import android.view.View; +import android.view.ViewGroup; +import android.widget.ImageView; + +import com.alibaba.android.arouter.facade.annotation.Route; +import com.binioter.guideview.Guide; +import com.binioter.guideview.GuideBuilder; +import com.yunbao.common.Constants; +import com.yunbao.common.bean.ActiveBean; +import com.yunbao.common.http.live.LiveNetManager; +import com.yunbao.common.utils.L; +import com.yunbao.common.utils.RouteUtil; +import com.yunbao.common.utils.SpUtil; +import com.yunbao.video.R; +import com.yunbao.video.utils.LottieComponent; +import com.yunbao.video.utils.VideoStorge; +import com.yunbao.video.views.VideoScrollViewHolder; + +import java.util.ArrayList; +import java.util.List; + +/** + * Created by cxf on 2018/11/26. + */ + +@Route(path = RouteUtil.PATH_VIDEO_PLAY) +public class VideoPlayNewActivity extends AbsVideoPlayActivity { + + private View viewBottom; + private ImageView btn_back; + + public static void forward(Context context, int position, String videoKey, int page) { + Intent intent = new Intent(context, VideoPlayNewActivity.class); + intent.putExtra(Constants.VIDEO_POSITION, position); + intent.putExtra(Constants.VIDEO_KEY, videoKey); + intent.putExtra(Constants.VIDEO_PAGE, page); + context.startActivity(intent); + } + + + public static void forwardSingle(Context context, ActiveBean videoBean) { + if (videoBean == null) { + return; + } + List list = new ArrayList<>(); + list.add(videoBean); + VideoStorge.getInstance().put(Constants.VIDEO_SINGLE, list); + Intent intent = new Intent(context, VideoPlayNewActivity.class); + intent.putExtra(Constants.VIDEO_POSITION, 0); + intent.putExtra(Constants.VIDEO_KEY, Constants.VIDEO_SINGLE); + intent.putExtra(Constants.VIDEO_PAGE, 1); + context.startActivity(intent); + } + + public static void forwardSingle(Context context, String id) { + LiveNetManager.get(context).getDynamicInfo(id, new com.yunbao.common.http.base.HttpCallback() { + @Override + public void onSuccess(ActiveBean data) { + List list = new ArrayList<>(); + list.add(data); + VideoStorge.getInstance().put(Constants.VIDEO_SINGLE, list); + Intent intent = new Intent(context, VideoPlayNewActivity.class); + intent.putExtra(Constants.VIDEO_POSITION, 0); + intent.putExtra(Constants.VIDEO_KEY, Constants.VIDEO_SINGLE); + intent.putExtra(Constants.VIDEO_PAGE, 1); + context.startActivity(intent); + } + + @Override + public void onError(String error) { + + } + }); + } + + + + @Override + protected int getLayoutId() { + return R.layout.activity_video_play; + } + + @Override + protected boolean isStatusBarWhite() { + return true; + } + + @Override + protected void main() { + super.main(); + Intent intent = getIntent(); + mVideoKey = intent.getStringExtra(Constants.VIDEO_KEY); + if (TextUtils.isEmpty(mVideoKey)) { + return; + } + ActiveBean bean=intent.getParcelableExtra("ActiveBean"); + if(bean!=null){ + List list = new ArrayList<>(); + list.add(bean); + VideoStorge.getInstance().put(Constants.VIDEO_SINGLE, list); + } + int position = intent.getIntExtra(Constants.VIDEO_POSITION, 0); + int page = intent.getIntExtra(Constants.VIDEO_PAGE, 1); + mVideoScrollViewHolder = new VideoScrollViewHolder(mContext, (ViewGroup) findViewById(R.id.container), position, mVideoKey, page); + mVideoScrollViewHolder.addToParent(); + mVideoScrollViewHolder.subscribeActivityLifeCycle(); + viewBottom = findViewById(R.id.viewBottom); + viewBottom.post(new Runnable() { + @Override + public void run() { + boolean read = SpUtil.getInstance().getBooleanValue(SpUtil.READ_VIDEO_GUIDE); + if (!read) { + showGuideView(); + } + } + }); + btn_back = findViewById(R.id.btn_back); + btn_back.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + finish(); + } + }); + } + + + @SuppressLint("ResourceType") + public void showGuideView() { + final GuideBuilder builder1 = new GuideBuilder(); + builder1.setTargetView(viewBottom) + .setAlpha(180) + .setHighTargetCorner(20) + .setHighTargetPadding(0) + .setExitAnimationId(android.R.anim.fade_out); + builder1.setOnVisibilityChangedListener(new GuideBuilder.OnVisibilityChangedListener() { + @Override + public void onShown() { + + } + + @Override + public void onDismiss() { + SpUtil.getInstance().setBooleanValue(SpUtil.READ_VIDEO_GUIDE, true); +// Toast.makeText(VideoPlayActivity.this, "引导层消失了", Toast.LENGTH_SHORT).show(); + } + }); + + builder1.addComponent(new LottieComponent()); + Guide guide = builder1.createGuide(); + guide.setShouldCheckLocInWindow(false); + guide.show(VideoPlayNewActivity.this); + + } + + @Override + public void onBackPressed() { + release(); + super.onBackPressed(); + } + + + @Override + protected void onDestroy() { + release(); + super.onDestroy(); + L.e("VideoPlayActivity------->onDestroy"); + } + + +} diff --git a/video/src/main/java/com/yunbao/video/views/VideoCommentViewHolder.java b/video/src/main/java/com/yunbao/video/views/VideoCommentViewHolder.java index b3aba28..d949765 100644 --- a/video/src/main/java/com/yunbao/video/views/VideoCommentViewHolder.java +++ b/video/src/main/java/com/yunbao/video/views/VideoCommentViewHolder.java @@ -27,7 +27,6 @@ import com.yunbao.common.adapter.CommentVideoAdapter; import com.yunbao.common.adapter.RefreshAdapter; import com.yunbao.common.bean.CommentBean; import com.yunbao.common.custom.CommonRefreshView; -import com.yunbao.common.custom.ItemDecoration; import com.yunbao.common.custom.MyLinearLayout3; import com.yunbao.common.glide.ImgLoader; import com.yunbao.common.http.CommonHttpUtil; @@ -36,7 +35,6 @@ import com.yunbao.common.utils.L; import com.yunbao.common.utils.RouteUtil; import com.yunbao.common.utils.ToastUtil; import com.yunbao.common.views.AbsViewHolder; -import com.yunbao.common.views.TopGradual; import com.yunbao.live.activity.LiveReportActivity; import com.yunbao.video.R; import com.yunbao.video.activity.AbsVideoCommentActivity; @@ -129,8 +127,6 @@ public class VideoCommentViewHolder extends AbsViewHolder implements View.OnClic mCommentNum = (TextView) findViewById(R.id.comment_num); mRefreshView = (CommonRefreshView) findViewById(R.id.refreshView); mRefreshView.setEmptyLayoutId(R.layout.view_no_data_comment); - ItemDecoration decoration = new ItemDecoration(mContext, 0x00000000, 5, 0); - mRefreshView.setItemDecoration(decoration); mRefreshView.setLoadMoreEnable(false); mRefreshView.setLayoutManager(new LinearLayoutManager(mContext, LinearLayoutManager.VERTICAL, false) { @Override 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 a7b207c..50a3f12 100644 --- a/video/src/main/java/com/yunbao/video/views/VideoPlayViewHolder.java +++ b/video/src/main/java/com/yunbao/video/views/VideoPlayViewHolder.java @@ -46,7 +46,6 @@ public class VideoPlayViewHolder extends AbsViewHolder implements ITXVodPlayList public VideoPlayViewHolder(Context context, ViewGroup parentView) { super(context, parentView); - } @Override @@ -58,7 +57,7 @@ public class VideoPlayViewHolder extends AbsViewHolder implements ITXVodPlayList public void init() { mCachePath = mContext.getCacheDir().getAbsolutePath(); mTXCloudVideoView = (TXCloudVideoView) findViewById(R.id.video_view); - mTXCloudVideoView.setRenderMode(TXLiveConstants.RENDER_MODE_FULL_FILL_SCREEN); + mTXCloudVideoView.setRenderMode(TXLiveConstants.RENDER_ROTATION_PORTRAIT); mPlayer = new TXVodPlayer(mContext); mTXVodPlayConfig = new TXVodPlayConfig(); mTXVodPlayConfig.setMaxCacheItems(15); @@ -87,6 +86,9 @@ public class VideoPlayViewHolder extends AbsViewHolder implements ITXVodPlayList if (mActionListener != null) { mActionListener.onPlayBegin(txVodPlayer.getDuration()); } + if (mActionListener != null) { + mActionListener.onFirstFrame(); + } break; case TXLiveConstants.PLAY_EVT_PLAY_LOADING: //开始加载的回调 if (mActionListener != null) { @@ -111,7 +113,7 @@ public class VideoPlayViewHolder extends AbsViewHolder implements ITXVodPlayList } break; case TXLiveConstants.PLAY_EVT_CHANGE_RESOLUTION://获取到视频宽高回调 - onVideoSizeChanged(bundle.getInt("EVT_PARAM1", 0), bundle.getInt("EVT_PARAM2", 0)); + onVideoSizeChanged( bundle.getInt("EVT_PARAM2", 0),bundle.getInt("EVT_PARAM1", 0)); break; case TXLiveConstants.PLAY_EVT_PLAY_PROGRESS: if (mActionListener != null) { @@ -133,9 +135,23 @@ public class VideoPlayViewHolder extends AbsViewHolder implements ITXVodPlayList */ public void onVideoSizeChanged(float videoWidth, float videoHeight) { if (mTXCloudVideoView != null && videoWidth > 0 && videoHeight > 0) { + RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) mTXCloudVideoView.getLayoutParams(); + /* + int videoViewHeight = params.height; + int videoViewWidth = params.width; + if (videoWidth < videoViewWidth && videoHeight >= videoViewHeight) { + params.width = (int) (videoViewHeight / (videoHeight / videoViewHeight)); + } else if (videoWidth > videoViewWidth && videoHeight >= videoViewHeight) { + params.width = (int) (videoViewHeight / (videoHeight / videoWidth)); + } + mTXCloudVideoView.requestLayout(); + if (mVideoCover != null && mVideoCover.getVisibility() == View.VISIBLE) { + mVideoCover.setVisibility(View.INVISIBLE); + }*/ int targetH = 0; if (videoWidth / videoHeight > 0.5625f) {//横屏 9:16=0.5625 + /*targetH = (int) (videoHeight*(videoWidth/videoHeight));*/ targetH = (int) (mTXCloudVideoView.getWidth() / videoWidth * videoHeight); } else { targetH = ViewGroup.LayoutParams.MATCH_PARENT;