Android高级控件(四)——VideoView 实现引导页播放视频欢迎效果,超级简单却十分的炫酷...

本文介绍如何使用Android的VideoView实现应用启动时的全屏视频播放效果,通过自定义VideoView确保不同尺寸设备上的全屏显示,并实现视频循环播放。

Android高级控件(四)——VideoView 实现引导页播放视频欢迎效果,超级简单却十分的炫酷


是不是感觉QQ空间什么的每次新版本更新那炫炫的引导页就特别的激动,哈哈,其实他实现起来真的很简单很简单,就一个官方自带的VideoView就可以实现了,但是官方的空间有个弊端就是不能全屏,及时你设置了match_parent也不行,有些手机上就有黑边,这里我们现在res目录下新建一个raw文件夹,然后把我们要播放的视频放进去,我们这里只是做了一个循环播放视频的效果,首先我们重写下VideoView,啥也不干,就是让他铺满屏幕,这个方法也是看到某网站的一个教学视频,不过再怎么说也是非分简单,视频素材也是直接拿过来用的,不打广告哈….

CustomVideoView

package com.lgl.mp4index;

import android.content.Context;
import android.media.MediaPlayer;
import android.util.AttributeSet;
import android.view.KeyEvent;
import android.widget.VideoView;

/**
 * 视频播放,主要是因为手机的大小很多,不能保证原生的VideoView能实现全屏
 * Created by lgl on 16/2/18.
 */
public class CustomVideoView extends VideoView {

    public CustomVideoView(Context context) {
        super(context);
    }

    public CustomVideoView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public CustomVideoView(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        //我们重新计算高度
        int width = getDefaultSize(0, widthMeasureSpec);
        int height = getDefaultSize(0, heightMeasureSpec);
        setMeasuredDimension(width, height);
    }

    @Override
    public void setOnPreparedListener(MediaPlayer.OnPreparedListener l) {
        super.setOnPreparedListener(l);
    }

    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event) {
        return super.onKeyDown(keyCode, event);
    }
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <com.lgl.mp4index.CustomVideoView
        android:id="@+id/videoview"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

    <Button
        android:id="@+id/btn_start"
        android:layout_width="100dp"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:layout_marginBottom="56dp"
        android:text="进入" />
</RelativeLayout>

MainActivity

package com.lgl.mp4index;

import android.media.MediaPlayer;
import android.net.Uri;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity implements View.OnClickListener{

    private CustomVideoView videoview;
    private Button btn_start;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        initView();
    }

    /**
     * 初始化
     */
    private void initView() {
        btn_start = (Button) findViewById(R.id.btn_start);
        btn_start.setOnClickListener(this);

        videoview = (CustomVideoView) findViewById(R.id.videoview);
        //设置播放加载路径
        videoview.setVideoURI(Uri.parse("android.resource://"+getPackageName()+"/"+R.raw.media));
        //播放
        videoview.start();
        //循环播放
        videoview.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
            @Override
            public void onCompletion(MediaPlayer mediaPlayer) {
                videoview.start();
            }
        });

    }

    @Override
    public void onClick(View view) {
        switch (view.getId()){
            case R.id.btn_start:
                Toast.makeText(this,"进入了主页",Toast.LENGTH_SHORT).show();
            break;
        }
    }
}

就是这么的简单…..不要说我这个帖子水哦,我们来运行一下

这里写图片描述

Demo就不上传了,就这么点代码…

仿蚂蜂窝自由行和慕课网视频欢迎页一.资源准备三个比较短小的视频视频下载二.开始编写代码1.在项目的res下新建一个raw文件夹,放入准备好的这三个视频2.自定义播放视频CustomVideoView 在这个自定义View里面提供一个播放视频的方法。用户只需要传入播放路径就可以了,并且可一循环播放。package cn.bluemobi.dylan.welcomevideopager; import android.content.Context; import android.media.MediaPlayer; import android.net.Uri; import android.util.AttributeSet; import android.view.View; import android.widget.VideoView; /**  * 可以播放视频的View  * Created by yuandl on 2016-11-10.  */ public class CustomVideoView extends VideoView {     public CustomVideoView(Context context) {         super(context);     }     public CustomVideoView(Context context, AttributeSet attrs, int defStyleAttr) {         super(context, attrs, defStyleAttr);     }     public CustomVideoView(Context context, AttributeSet attrs) {         super(context, attrs);     }     @Override     protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {         super.onMeasure(widthMeasureSpec, heightMeasureSpec);         setMeasuredDimension(View.MeasureSpec.getSize(widthMeasureSpec), View.MeasureSpec.getSize(heightMeasureSpec));     }     /**      * 播放视频      *      * @param uri 播放地址      */     public void playVideo(Uri uri) {         if (uri == null) {             throw new IllegalArgumentException("Uri can not be null");         }         /**设置播放路径**/         setVideoURI(uri);         /**开始播放**/         start();         setOnPreparedListener(new MediaPlayer.OnPreparedListener() {             @Override             public void onPrepared(MediaPlayer mp) {                 /**设置循环播放**/                 mp.setLooping(true);             }         });         setOnErrorListener(new MediaPlayer.OnErrorListener() {             @Override             public boolean onError(MediaPlayer mp, int what, int extra) {                 return true;             }         });     } }3.建立没个欢迎页面的Fragment去加载自定义视频View的视图package cn.bluemobi.dylan.welcomevideopager; import android.net.Uri; import android.os.Bundle; import android.support.annotation.Nullable; import android.support.v4.app.Fragment; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; /**  * Created by yuandl on 2016-11-10.  */ public class GuildFragment extends Fragment {     private CustomVideoView customVideoView;     @Nullable     @Override     public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {         customVideoView = new CustomVideoView(getContext());         /**获取参数,根据不同的参数播放不同的视频**/         int index = getArguments().getInt("index");         Uri uri;         if (index == 1) {             uri = Uri.parse("android.resource://"   getActivity().getPackageName()   "/"   R.raw.guide_1);         } else if (index == 2) {             uri = Uri.parse("android.resource://"   getActivity().getPackageName()   "/"   R.raw.guide_2);         } else {             uri = Uri.parse("android.resource://"   getActivity().getPackageName()   "/"   R.raw.guide_3);         }         /**播放视频**/         customVideoView.playVideo(uri);         return customVideoView;     }     /**      * 记得在销毁的时候让播放视频终止      */     @Override     public void onDestroy() {         super.onDestroy();         if (customVideoView != null) {             customVideoView.stopPlayback();         }     } }4.界面布局<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"     android:layout_width="match_parent"     android:layout_height="match_parent">     <android.support.v4.view.ViewPager         android:id="@ id/vp"         android:layout_width="match_parent"         android:layout_height="match_parent"></android.support.v4.view.ViewPager>     <LinearLayout         android:layout_width="wrap_content"         android:layout_height="wrap_content"         android:layout_alignParentBottom="true"         android:layout_centerHorizontal="true"         android:layout_marginBottom="130dp"         android:orientation="horizontal">         <ImageView             android:id="@ id/iv1"             android:layout_width="10dp"             android:layout_height="10dp"             android:src="@mipmap/dot_focus" />         <ImageView             android:id="@ id/iv2"             android:layout_width="10dp"             android:layout_height="10dp"             android:layout_marginLeft="10dp"             android:src="@mipmap/dot_normal" />         <ImageView             android:id="@ id/iv3"             android:layout_width="10dp"             android:layout_height="10dp"             android:layout_marginLeft="10dp"             android:src="@mipmap/dot_normal" />     </LinearLayout>     <Button         android:id="@ id/bt_start"         android:layout_width="wrap_content"         android:layout_height="wrap_content"         android:layout_alignParentBottom="true"         android:layout_centerHorizontal="true"         android:layout_marginBottom="50dp"         android:background="@mipmap/bt_start"         android:textColor="@android:color/white"         android:visibility="gone" /> </RelativeLayout>5.给界面添加Fragmentpackage cn.bluemobi.dylan.welcomevideopager; import android.os.Bundle; import android.support.v4.app.Fragment; import android.support.v4.app.FragmentManager; import android.support.v4.app.FragmentPagerAdapter; import android.support.v4.view.ViewPager; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.Button; import android.widget.ImageView; import java.util.ArrayList; import java.util.List; public class MainActivity extends AppCompatActivity {     private ViewPager vp;     private ImageView iv1;     private ImageView iv2;     private ImageView iv3;     private Button bt_start;     private List<Fragment> fragments;     private void assignViews() {         vp = (ViewPager) findViewById(R.id.vp);         iv1 = (ImageView) findViewById(R.id.iv1);         iv2 = (ImageView) findViewById(R.id.iv2);         iv3 = (ImageView) findViewById(R.id.iv3);         bt_start = (Button) findViewById(R.id.bt_start);     }     @Override     protected void onCreate(Bundle savedInstanceState) {         super.onCreate(savedInstanceState);         setContentView(R.layout.activity_main);         assignViews();         initData();         initView();     }     /**      * 初始化数据,添加三个Fragment      */     private void initData() {         fragments = new ArrayList<>();         Fragment fragment1 = new GuildFragment();         Bundle bundle1 = new Bundle();         bundle1.putInt("index", 1);         fragment1.setArguments(bundle1);         fragments.add(fragment1);         Fragment fragment2 = new GuildFragment();         Bundle bundle2 = new Bundle();         bundle2.putInt("index", 2);         fragment2.setArguments(bundle2);         fragments.add(fragment2);         Fragment fragment3 = new GuildFragment();         Bundle bundle3 = new Bundle();         bundle3.putInt("index", 3);         fragment3.setArguments(bundle3);         fragments.add(fragment3);     }     /**      * 设置ViewPager的适配器和滑动监听      */     private void initView() {         vp.setOffscreenPageLimit(3);         vp.setAdapter(new MyPageAdapter(getSupportFragmentManager()));         vp.addOnPageChangeListener(new MyPageChangeListener());     }     /**      * ViewPager适配器      */     private class MyPageAdapter extends FragmentPagerAdapter {         public MyPageAdapter(FragmentManager fm) {             super(fm);         }         @Override         public Fragment getItem(int position) {             return fragments.get(position);         }         @Override         public int getCount() {             return fragments.size();         }     }     /**      * ViewPager滑动页面监听器      */     private class MyPageChangeListener implements ViewPager.OnPageChangeListener {         @Override         public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {         }         /**          * 根据页面不同动态改变红点和在最后一页显示立即体验按钮          *          * @param position          */         @Override         public void onPageSelected(int position) {             bt_start.setVisibility(View.GONE);             iv1.setImageResource(R.mipmap.dot_normal);             iv2.setImageResource(R.mipmap.dot_normal);             iv3.setImageResource(R.mipmap.dot_normal);             if (position == 0) {                 iv1.setImageResource(R.mipmap.dot_focus);             } else if (position == 1) {                 iv2.setImageResource(R.mipmap.dot_focus);             } else {                 iv3.setImageResource(R.mipmap.dot_focus);                 bt_start.setVisibility(View.VISIBLE);             }         }         @Override         public void onPageScrollStateChanged(int state) {         }     } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值