广告
返回顶部
首页 > 资讯 > 精选 >Android自定义videoview仿抖音界面的示例分析
  • 294
分享到

Android自定义videoview仿抖音界面的示例分析

2023-06-15 00:06:08 294人浏览 安东尼
摘要

这篇文章主要介绍Android自定义videoview仿抖音界面的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Android是什么Android是一种基于linux内核的自由及开放源代码的操作系统,主要使用

这篇文章主要介绍Android自定义videoview仿抖音界面的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

Android是什么

Android是一种基于linux内核的自由及开放源代码的操作系统,主要使用于移动设备,如智能手机和平板电脑,由美国Google公司和开放手机联盟领导及开发

具体内容如下

效果图

和抖音的界面效果一模一样,而且可以自定义,需要什么页面,请自己定义

自定义videoview

package com.example.myapplication20;  import android.content.Context;import android.util.AttributeSet;import android.widget.VideoView; public class CusVideoView extends VideoView {    public CusVideoView(Context context) {        super(context);    }     public CusVideoView(Context context, AttributeSet attrs) {        super(context, attrs);    }     public CusVideoView(Context context, AttributeSet attrs, int defStyleAttr) {        super(context, attrs, defStyleAttr);    }     @Override    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {        super.onMeasure(widthMeasureSpec, heightMeasureSpec);        int width = getDefaultSize(getWidth(), widthMeasureSpec);        int height = getDefaultSize(getHeight(), heightMeasureSpec);        setMeasuredDimension(width, height);    }}

xml界面

<?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:id="@+id/mRootView"    android:layout_width="match_parent"    android:layout_height="match_parent">     <ImageView        android:id="@+id/mThumb"        android:layout_width="match_parent"        android:layout_height="match_parent"        android:clickable="false"        android:focusable="false"        android:scaleType="centerCrop"        android:visibility="visible" />     <ImageView        android:id="@+id/mPlay"        android:layout_width="100dp"        android:layout_height="100dp"        android:layout_centerInParent="true"        android:alpha="0"        android:clickable="true"        android:focusable="true"        android:src="@drawable/play_arrow" />      <LinearLayout        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_alignParentBottom="true"        android:layout_marginLeft="10dp"        android:layout_marginBottom="60dp"        android:orientation="vertical">         <TextView            android:id="@+id/mTitle"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:lineSpacingExtra="5dp"            android:textColor="@android:color/white"            android:textSize="16sp"            tools:text="测试测试数据哈哈哈哈\n家里几个垃圾了个两个垃圾" />      </LinearLayout>     <com.example.myapplication20.CusVideoView        android:id="@+id/mVideoView"        android:layout_width="match_parent"        android:layout_height="match_parent"        android:clickable="false"        android:focusable="false" /></RelativeLayout>

drawable

<vector android:alpha="0.61" android:height="24dp"    android:viewportHeight="24.0" android:viewportWidth="24.0"    android:width="24dp" xmlns:android="http://schemas.android.com/apk/res/android">    <path android:fillColor="#99ffffff" android:pathData="M8,5v14l11,-7z"/></vector>

主界面设置地址,注意,本demo使用的是本地的视频文件,文件存储再../res/raw文件夹里面,请自行获取

package com.example.myapplication20; import androidx.annotation.Nullable;import androidx.appcompat.app.AppCompatActivity;  import android.media.MediaPlayer;import android.net.Uri;import android.os.Bundle;import android.util.Log;import android.view.View;import android.widget.ImageView;import android.widget.TextView; import androidx.annotation.Nullable;import androidx.appcompat.app.AppCompatActivity;  public class MainActivity extends AppCompatActivity {    CusVideoView mVideoView;    private int[] videos = {R.raw.v1, R.raw.v2, R.raw.qi};    TextView mTitle;      @Override    protected void onCreate(@Nullable Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);         mVideoView = findViewById(R.id.mVideoView);        mTitle = findViewById(R.id.mTitle);         String url = "android.resource://" + getPackageName() + "/" + videos[1];        Log.e("TAG", "video_onCreate: " + url);         mVideoView.setVideoURI(Uri.parse(url));        mTitle.setText("@王燕\n一起来跳支舞吧");    }      @Override    protected void onStart() {        super.onStart();        playVideo();    }     @Override    protected void onDestroy() {        super.onDestroy();        releaseVideo();    }     //播放    private void playVideo() {         Log.e("TAG", "play_video");         // View itemView = mRecycler.getChildAt(0);        final CusVideoView mVideoView = findViewById(R.id.mVideoView);        final ImageView mPlay = findViewById(R.id.mPlay);        final ImageView mThumb = findViewById(R.id.mThumb);        final MediaPlayer[] mMediaPlayer = new MediaPlayer[1];        mVideoView.start();         mVideoView.setOnInfoListener(new MediaPlayer.OnInfoListener() {            @Override            public boolean onInfo(MediaPlayer mp, int what, int extra) {                mMediaPlayer[0] = mp;                mp.setLooping(true);                mThumb.animate().alpha(0).setDuration(200).start();                return false;            }        });         //暂停控制        mPlay.setOnClickListener(new View.OnClickListener() {            boolean isPlaying = true;             @Override            public void onClick(View v) {                if (mVideoView.isPlaying()) {                    mPlay.animate().alpha(1f).start();                    mVideoView.pause();                    isPlaying = false;                } else {                    mPlay.animate().alpha(0f).start();                    mVideoView.start();                    isPlaying = true;                }            }        });    }     //释放    private void releaseVideo() {         Log.e("TAG", "releaseVideo_video");         //  View itemView = mRecycler.getChildAt(index);        final CusVideoView mVideoView = findViewById(R.id.mVideoView);        final ImageView mThumb = findViewById(R.id.mThumb);        final ImageView mPlay = findViewById(R.id.mPlay);        mVideoView.stopPlayback();        mThumb.animate().alpha(1).start();        mPlay.animate().alpha(0f).start();    }  }

以上是“Android自定义videoview仿抖音界面的示例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网精选频道!

--结束END--

本文标题: Android自定义videoview仿抖音界面的示例分析

本文链接: https://www.lsjlt.com/news/276060.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android自定义videoview仿抖音界面的示例分析
    这篇文章主要介绍Android自定义videoview仿抖音界面的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Android是什么Android是一种基于Linux内核的自由及开放源代码的操作系统,主要使用...
    99+
    2023-06-15
  • Android自定义videoview仿抖音界面
    本文实例为大家分享了Android自定义videoview仿抖音界面的具体代码,供大家参考,具体内容如下 1.效果图 和抖音的界面效果一模一样,而且可以自定义,需要什么页面,请自己定...
    99+
    2022-11-12
  • Android自定义仿ios加载弹窗的示例分析
    小编给大家分享一下Android自定义仿ios加载弹窗的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!具体内容如下效果如下:IosLoadDialog类(可直接复制):public class ...
    99+
    2023-06-15
  • Android编程中自定义组件的示例分析
    这篇文章主要介绍了Android编程中自定义组件的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Android是什么Android是一种基于Linux内核的自由及开放...
    99+
    2023-05-31
    android
  • asp.net中mvc4自定义404页面的示例分析
    这篇文章给大家分享的是有关asp.net中mvc4自定义404页面的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。定义404方法当然有很多种。不同的方法所展现的形式也不一...
    99+
    2022-10-19
  • android中自定义View之复合控件的示例分析
    这篇文章给大家分享的是有关android中自定义View之复合控件的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。复合控件可以很好地创建出具有重用功能的控件集合。很多的APP都有一些共通的UI界面,为了统...
    99+
    2023-06-15
  • Android中自定义view中事件分发机制与处理的示例分析
    这篇文章将为大家详细讲解有关Android中自定义view中事件分发机制与处理的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。题引事件只有一个,多个人想要处理,处理的对象不是我们想给的对象就是事件...
    99+
    2023-06-25
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作