返回顶部
首页 > 资讯 > 精选 >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://lsjlt.com/news/276060.html(转载时请注明来源链接)

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

猜你喜欢
  • Android自定义videoview仿抖音界面的示例分析
    这篇文章主要介绍Android自定义videoview仿抖音界面的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Android是什么Android是一种基于Linux内核的自由及开放源代码的操作系统,主要使用...
    99+
    2023-06-15
  • Android自定义videoview仿抖音界面
    本文实例为大家分享了Android自定义videoview仿抖音界面的具体代码,供大家参考,具体内容如下 1.效果图 和抖音的界面效果一模一样,而且可以自定义,需要什么页面,请自己定...
    99+
    2024-04-02
  • Android自定义仿ios加载弹窗的示例分析
    小编给大家分享一下Android自定义仿ios加载弹窗的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!具体内容如下效果如下:IosLoadDialog类(可直接复制):public class ...
    99+
    2023-06-15
  • Android自定义View仿QQ健康界面
    最近一直在学习自定义View相关的知识,今天给大家带来的是QQ健康界面的实现。先看效果图: 可以设置数字颜色,字体颜色,运动步数,运动排名,运动平均步数,虚线下方的蓝色指...
    99+
    2022-06-06
    view 界面 Android
  • Android ListView自定义Adapter实现仿QQ界面
    PS:listview中有一些简单使用的适配器,如:SimpleAdapter:构造方法SimpleAdapter(Context context,List<Map<String,?>> data,reStr...
    99+
    2023-05-30
    listview adapter
  • android自定义ImageView仿图片上传示例
    看下效果图 主要看下自定义view 代码 public class ProcessImageView extends ImageView{ private Cont...
    99+
    2022-06-06
    图片上传 示例 图片 Android
  • phpunit自定义的示例分析
    这篇文章主要介绍phpunit自定义的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!下载:wget  https://phar.phpunit.de/ph...
    99+
    2024-04-02
  • asp.net中mvc4自定义404页面的示例分析
    这篇文章给大家分享的是有关asp.net中mvc4自定义404页面的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。定义404方法当然有很多种。不同的方法所展现的形式也不一...
    99+
    2024-04-02
  • Android编程中自定义组件的示例分析
    这篇文章主要介绍了Android编程中自定义组件的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Android是什么Android是一种基于Linux内核的自由及开放...
    99+
    2023-05-31
    android
  • angular4自定义组件的示例分析
    这篇文章主要为大家展示了“angular4自定义组件的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“angular4自定义组件的示例分析”这篇文章吧。在...
    99+
    2024-04-02
  • AngularJS自定义指令的示例分析
    这篇文章主要介绍AngularJS自定义指令的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!前言除了 AngularJS 内置的指令外,我们还可以创建自定义指令。 通过 .d...
    99+
    2024-04-02
  • CSS自定义属性的示例分析
    这篇文章主要为大家展示了“CSS自定义属性的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“CSS自定义属性的示例分析”这篇文章吧。 兼容性 第一个问...
    99+
    2024-04-02
  • Vue自定义指令的示例分析
    这篇文章主要介绍Vue自定义指令的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在 AngularJs 中,它的指令使用 directive ( name,factor_fu...
    99+
    2024-04-02
  • Vue.directive自定义指令的示例分析
    这篇文章主要介绍Vue.directive自定义指令的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.复习一下Vue自定义指令的代码,结果出现一个很无语的结果,先贴代码。2...
    99+
    2024-04-02
  • Android仿360悬浮小球自定义view实现示例
    Android仿360悬浮小球自定义view实现示例 效果图如下: 实现当前这种类似的效果 和360小球 悬浮桌面差不错类似。这种效果是如何实现的呢。废话不多说 ,直接...
    99+
    2022-06-06
    view 示例 自定义view Android
  • Android自定义Livedata使用示例解析
    目录前言Livedata分析自定义Livedata总结前言 我们在开发中在使用MVVM的情况下经常会配合livedata来达到快速开发的效果,但是一般都是在activity或者fra...
    99+
    2022-12-08
    Android 自定义Livedata Android Livedata
  • android中自定义View之复合控件的示例分析
    这篇文章给大家分享的是有关android中自定义View之复合控件的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。复合控件可以很好地创建出具有重用功能的控件集合。很多的APP都有一些共通的UI界面,为了统...
    99+
    2023-06-15
  • android自定义view之实现日历界面实例
    现在网上有很多自定义view实现日历的demo,今天讲一讲如何自己实现这个自定义view。 看一下最终效果图: 在这个自定义view中,我使用了各种奇技淫巧的方法来实现这个日...
    99+
    2022-06-06
    view 界面 Android
  • Android编程自定义Notification实例分析
    本文实例讲述了Android编程自定义Notification的用法。分享给大家供大家参考,具体如下: Notification是一种让你的应用程序在不使用Activity的情...
    99+
    2022-06-06
    notification Android
  • SQL Function自定义函数的示例分析
    小编给大家分享一下SQL Function自定义函数的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!目录产生背景(已经有了存储过程,为什么还要使用自定义函数)发展历史构成使用方法适...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作