Android實現(xiàn)短視頻畫心效果
更新時間:2021年05月25日 11:29:31 作者:韓木春華
這篇文章主要為大家詳細介紹了Android實現(xiàn)短視頻畫心效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了Android實現(xiàn)短視頻畫心效果的具體代碼,供大家參考,具體內(nèi)容如下
布局
主布局
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout 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" android:orientation="vertical" tools:context=".MainActivity"> <androidx.recyclerview.widget.RecyclerView android:id="@+id/ree" android:layout_width="match_parent" android:layout_height="match_parent"></androidx.recyclerview.widget.RecyclerView> <SurfaceView android:id="@+id/surface" android:layout_width="match_parent" android:layout_height="match_parent"></SurfaceView> </RelativeLayout>
適配器布局`
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> <com.shuyu.gsyvideoplayer.video.StandardGSYVideoPlayer android:id="@+id/detail" android:layout_width="match_parent" android:layout_height="match_parent" /> </LinearLayout>
Activity頁面邏輯
package com.example.pagfany; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.graphics.PixelFormat; import android.graphics.PorterDuff; import android.graphics.PorterDuffXfermode; import android.graphics.RectF; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.view.Display; import android.view.MotionEvent; import android.view.SurfaceHolder; import android.view.SurfaceView; import android.view.View; import android.widget.Toast; import androidx.annotation.NonNull; import androidx.appcompat.app.AppCompatActivity; import androidx.recyclerview.widget.RecyclerView; import java.util.ArrayList; import java.util.List; import butterknife.BindView; import butterknife.ButterKnife; public class MainActivity extends AppCompatActivity implements BaseLinearLayoutManager.OnListener, SurfaceHolder.Callback { @BindView(R.id.ree) RecyclerView ree; @BindView(R.id.surface) SurfaceView surface; private BaseeAdap baseeAdap; private SurfaceHolder surfaceHolder; private Display display; Handler handler=new Handler(){ @Override public void handleMessage(@NonNull Message msg) {//清除畫板上的內(nèi)容 super.handleMessage(msg); if (msg.what==1){ Canvas canvas = surfaceHolder.lockCanvas(); Paint paint=new Paint(Paint.ANTI_ALIAS_FLAG); paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.CLEAR)); paint.setColor(Color.TRANSPARENT); RectF rectF = new RectF(0,0,display.getWidth(),display.getHeight()); canvas.drawRect(rectF,paint); surfaceHolder.unlockCanvasAndPost(canvas); } } }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); ButterKnife.bind(this); BaseLinearLayoutManager baseLinearLayoutManager = new BaseLinearLayoutManager(this); baseLinearLayoutManager.setOnListener(this);//接口回調(diào) ree.setLayoutManager(baseLinearLayoutManager); List<StringBean> beans = new ArrayList<>(); for (int i = 0; i < shuzu.videoUrls.length; i++) { beans.add(new StringBean(shuzu.videoUrls[i])); } baseeAdap = new BaseeAdap(R.layout.basevideo, beans); ree.setAdapter(baseeAdap); display=getWindowManager().getDefaultDisplay();//通過管理器獲取屏幕信息 surface.setZOrderOnTop(true);//置頂 surface.getHolder().setFormat(PixelFormat.TRANSPARENT);//畫板透明社 surface.getHolder().addCallback(this);//接口回調(diào) } @Override public void init() { } @Override public void reselat() { baseeAdap.getreselat();//調(diào)用適配器的方法 } @Override public void getplay(int position) { baseeAdap.gepalay(position);//滑動播放??!有錯誤 } @Override protected void onDestroy() { super.onDestroy(); baseeAdap.getAllreselat();//關閉程序清空緩存 } private long time=0; private float y; private float x; @Override public void surfaceCreated(@NonNull SurfaceHolder holder) { surfaceHolder=holder; surface.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { switch (event.getAction()){//雙擊 case MotionEvent.ACTION_DOWN://按下按鈕 if (time==0){ time=System.currentTimeMillis();//第一次時間 }else { if (System.currentTimeMillis()-time<250){//當前時間 減去time y = event.getY(); x = event.getX();//點擊的坐標 huaxin();//調(diào)用花心的方法 handler.sendEmptyMessageAtTime(1,500); }else { time=System.currentTimeMillis(); } } break; } return false; } }); } private void huaxin() { Canvas canvas = surfaceHolder.lockCanvas(); Paint paint=new Paint(Paint.ANTI_ALIAS_FLAG); paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.CLEAR));//當想設置圖片重疊的相交狀態(tài)時 paint.setColor(Color.TRANSPARENT); RectF rectF = new RectF(0,0,display.getWidth(),display.getHeight()); canvas.drawRect(rectF,paint);//清空畫板 Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.mipmap.ic_launcher); canvas.drawBitmap(bitmap,x,y,null);//注意不要用畫筆 當前畫筆是透明色 surfaceHolder.unlockCanvasAndPost(canvas); } @Override public void surfaceChanged(@NonNull SurfaceHolder holder, int format, int width, int height) { } @Override public void surfaceDestroyed(@NonNull SurfaceHolder holder) { } }
適配器
package com.example.pagfany; import android.util.Log; import androidx.annotation.Nullable; import com.chad.library.adapter.base.BaseQuickAdapter; import com.chad.library.adapter.base.BaseViewHolder; import com.shuyu.gsyvideoplayer.GSYVideoManager; import com.shuyu.gsyvideoplayer.video.StandardGSYVideoPlayer; import java.util.List; public class BaseeAdap extends BaseQuickAdapter<StringBean, BaseViewHolder> { private StandardGSYVideoPlayer standardGSYVideoPlayer; public BaseeAdap(int layoutResId, @Nullable List<StringBean> data) { super(layoutResId, data); } private int aa=-1; @Override protected void convert(BaseViewHolder helper, StringBean item) { standardGSYVideoPlayer =helper.getView(R.id.detail); standardGSYVideoPlayer.setUp(item.getA(),true,"美女"); standardGSYVideoPlayer.startPlayLogic(); } public void getreselat() { standardGSYVideoPlayer.release(); } public void getAllreselat() { GSYVideoManager.releaseAllVideos(); } public void gepalay(int position) { standardGSYVideoPlayer.setUp(shuzu.videoUrls[position],true,"美女"); standardGSYVideoPlayer.startPlayLogic(); } }
自定義線性布局
package com.example.pagfany; import android.content.Context; import android.util.Log; import android.view.View; import androidx.annotation.NonNull; import androidx.recyclerview.widget.LinearLayoutManager; import androidx.recyclerview.widget.PagerSnapHelper; import androidx.recyclerview.widget.RecyclerView; public class BaseLinearLayoutManager extends LinearLayoutManager implements RecyclerView.OnChildAttachStateChangeListener { public BaseLinearLayoutManager(Context context) { super(context); } public BaseLinearLayoutManager(Context context, int orientation, boolean reverseLayout) { super(context, orientation, reverseLayout); } private OnListener onListener;//接口 public void setOnListener(OnListener onListener) { this.onListener = onListener; } interface OnListener{ void init(); void reselat(); void getplay(int position); } private PagerSnapHelper pagerSnapHelper;// @Override public void onAttachedToWindow(RecyclerView view) { super.onAttachedToWindow(view); pagerSnapHelper=new PagerSnapHelper(); pagerSnapHelper.attachToRecyclerView(view);//RecyclerView的滑動 view.addOnChildAttachStateChangeListener(this);//滑動狀態(tài)監(jiān)聽 } private static final String TAG = "BaseLinearLayoutManager"; @Override public void onScrollStateChanged(int state) { super.onScrollStateChanged(state); switch (state){ case RecyclerView.SCROLL_STATE_IDLE: View snapView = pagerSnapHelper.findSnapView(this); int position = getPosition(snapView); onListener.getplay(position); Log.i(TAG, "onScrollStateChanged: "+position); break; } } @Override public void onChildViewAttachedToWindow(@NonNull View view) { Log.i(TAG, "onChildViewAttachedToWindow: "+132456); } @Override public void onChildViewDetachedFromWindow(@NonNull View view) { if (onListener!=null){ onListener.reselat();//滑動下一個頁面 讓上個視頻沒有聲音 清除緩存 } } }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
android RecycleView實現(xiàn)多級樹形列表
這篇文章主要為大家詳細介紹了android RecycleView實現(xiàn)多級樹形列表,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-05-05Android多點觸控技術(shù)實戰(zhàn) 針對圖片自由縮放和移動
這篇文章主要為大家詳細介紹了Android多點觸控技術(shù)實戰(zhàn),自由地對圖片進行縮放和移動,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10android開發(fā)教程之framework增加字符串資源和圖片等resource資源
這篇文章主要介紹了android開發(fā)中framework增加字符串資源和圖片等resource資源方法,需要的朋友可以參考下2014-02-02Android kotlin使用注解實現(xiàn)防按鈕連點功能的示例
這篇文章主要介紹了Android kotlin使用注解實現(xiàn)防按鈕連點功能的示例,幫助大家更好的理解和學習使用Android,感興趣的朋友可以了解下2021-03-03Android實現(xiàn)短信加密功能(發(fā)送加密短信、解密本地短信)
這篇文章主要介紹了android實現(xiàn)短信加密功能的相關資料,功能包括發(fā)送加密短信、解密本地短信,感興趣的小伙伴們可以參考一下2016-01-01RecylerView實現(xiàn)流布局StaggeredGridLayoutManager使用詳解
這篇文章主要為大家詳細介紹了RecylerView實現(xiàn)流布局StaggeredGridLayoutManager使用,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-09-09