Android實(shí)現(xiàn)短視頻畫心效果
本文實(shí)例為大家分享了Android實(shí)現(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);//滑動(dòng)播放?。∮绣e(cuò)誤
}
@Override
protected void onDestroy() {
super.onDestroy();
baseeAdap.getAllreselat();//關(guān)閉程序清空緩存
}
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();//第一次時(shí)間
}else {
if (System.currentTimeMillis()-time<250){//當(dāng)前時(shí)間 減去time
y = event.getY();
x = event.getX();//點(diǎn)擊的坐標(biāo)
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));//當(dāng)想設(shè)置圖片重疊的相交狀態(tài)時(shí)
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);//注意不要用畫筆 當(dāng)前畫筆是透明色
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的滑動(dòng)
view.addOnChildAttachStateChangeListener(this);//滑動(dòng)狀態(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();//滑動(dòng)下一個(gè)頁面 讓上個(gè)視頻沒有聲音 清除緩存
}
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
學(xué)習(xí)Android Material Design(RecyclerView代替ListView)
Android Material Design越來越流行,以前很常用的 ListView 現(xiàn)在也用RecyclerView代替了,實(shí)現(xiàn)原理還是相似的,感興趣的小伙伴們可以參考一下2016-01-01
Android實(shí)現(xiàn)水波紋外擴(kuò)效果的實(shí)例代碼
微信曾經(jīng)推出了一個(gè)查找附近好友的功能,大致功能是這樣的:屏幕上有一個(gè)按鈕,長按按鈕的時(shí)候,會(huì)有一圈圈水波紋的動(dòng)畫向外擴(kuò)散,松手后,動(dòng)畫結(jié)束2018-05-05
Android UI設(shè)計(jì)系列之自定義TextView屬性實(shí)現(xiàn)帶下劃線的文本框(4)
這篇文章主要介紹了Android UI設(shè)計(jì)系列之自定義TextView屬性實(shí)現(xiàn)帶下劃線的文本框,具有一定的實(shí)用性和參考價(jià)值,感興趣的小伙伴們可以參考一下2016-06-06
Android BroadcastReceiver傳輸機(jī)制詳解
Android開發(fā)的四大組件分別是:活動(dòng)(activity),用于表現(xiàn)功能;服務(wù)(service),后臺(tái)運(yùn)行服務(wù),不提供界面呈現(xiàn);廣播接受者(Broadcast Receive),勇于接收廣播;內(nèi)容提供者(Content Provider),支持多個(gè)應(yīng)用中存儲(chǔ)和讀取數(shù)據(jù),相當(dāng)于數(shù)據(jù)庫,本篇著重介紹廣播組件2023-01-01
Android Studio升級4.1.1后各種錯(cuò)誤和解決方案
這篇文章主要介紹了Android Studio升級4.1.1后各種錯(cuò)誤和解決方案,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12

