阿里云服务器免费领卷啦。

捡代码论坛-最全的游戏源码下载技术网站!

 找回密码
 立 即 注 册

QQ登录

只需一步,快速开始

搜索
关于源码区的附件失效或欺骗帖, 处理办法
查看: 21315|回复: 15

[安卓,android源码] Android酷炫欢迎页播放视频,仿蚂蜂窝自由行和慕课网源码下载

[复制链接]

4213

主题

210

回帖

12万

积分

管理员

管理员

Rank: 9Rank: 9Rank: 9

积分
127203
QQ
发表于 2016-11-14 10:51:08 | 显示全部楼层 |阅读模式
Android酷炫欢迎页播放视频,仿蚂蜂窝自由行和慕课网源码下载

今天无意间看到了蚂蜂窝自由行的app,启动页很酷炫。我记得以前慕课网有个版本的app欢迎页也是播放视频的。 今天就顺手写一个,代码比较简单,高手请略过。



一.资源准备

三个比较短小的视频:视频下载
二.开始编写代码

1.在项目的res下新建一个raw文件夹,放入准备好的这三个视频
2.自定义播放视频的CustomVideoView 在这个自定义View里面提供一个播放视频的方法。用户只需要传入播放路径就可以了,并且可一循环播放。



  1. package cn.bluemobi.dylan.welcomevideopager;
  2. import android.content.Context;
  3. import android.media.MediaPlayer;
  4. import android.net.Uri;
  5. import android.util.AttributeSet;
  6. import android.view.View;
  7. import android.widget.VideoView;

  8. /**
  9. * 可以播放视频的View
  10. * Created by yuandl on 2016-11-10.
  11. */

  12. public class CustomVideoView extends VideoView {
  13.     public CustomVideoView(Context context) {
  14.         super(context);
  15.     }

  16.     public CustomVideoView(Context context, AttributeSet attrs, int defStyleAttr) {
  17.         super(context, attrs, defStyleAttr);
  18.     }

  19.     public CustomVideoView(Context context, AttributeSet attrs) {
  20.         super(context, attrs);
  21.     }

  22.     @Override
  23.     protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  24.         super.onMeasure(widthMeasureSpec, heightMeasureSpec);
  25.         setMeasuredDimension(View.MeasureSpec.getSize(widthMeasureSpec), View.MeasureSpec.getSize(heightMeasureSpec));
  26.     }

  27.     /**
  28.      * 播放视频
  29.      *
  30.      * @param uri 播放地址
  31.      */
  32.     public void playVideo(Uri uri) {
  33.         if (uri == null) {
  34.             throw new IllegalArgumentException("Uri can not be null");
  35.         }
  36.         /**设置播放路径**/
  37.         setVideoURI(uri);
  38.         /**开始播放**/
  39.         start();
  40.         setOnPreparedListener(new MediaPlayer.OnPreparedListener() {

  41.             @Override
  42.             public void onPrepared(MediaPlayer mp) {
  43.                 /**设置循环播放**/
  44.                 mp.setLooping(true);
  45.             }
  46.         });
  47.         setOnErrorListener(new MediaPlayer.OnErrorListener() {

  48.             @Override
  49.             public boolean onError(MediaPlayer mp, int what, int extra) {
  50.                 return true;
  51.             }
  52.         });
  53.     }
  54. }
复制代码
3.建立没个欢迎页面的Fragment去加载自定义视频View的视图

  1. package cn.bluemobi.dylan.welcomevideopager;

  2. import android.net.Uri;
  3. import android.os.Bundle;
  4. import android.support.annotation.Nullable;
  5. import android.support.v4.app.Fragment;
  6. import android.view.LayoutInflater;
  7. import android.view.View;
  8. import android.view.ViewGroup;

  9. /**
  10. * Created by yuandl on 2016-11-10.
  11. */

  12. public class GuildFragment extends Fragment {

  13.     private CustomVideoView customVideoView;

  14.     @Nullable
  15.     @Override
  16.     public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
  17.         customVideoView = new CustomVideoView(getContext());
  18.         /**获取参数,根据不同的参数播放不同的视频**/
  19.         int index = getArguments().getInt("index");
  20.         Uri uri;
  21.         if (index == 1) {
  22.             uri = Uri.parse("android.resource://" + getActivity().getPackageName() + "/" + R.raw.guide_1);
  23.         } else if (index == 2) {
  24.             uri = Uri.parse("android.resource://" + getActivity().getPackageName() + "/" + R.raw.guide_2);
  25.         } else {
  26.             uri = Uri.parse("android.resource://" + getActivity().getPackageName() + "/" + R.raw.guide_3);
  27.         }
  28.         /**播放视频**/
  29.         customVideoView.playVideo(uri);
  30.         return customVideoView;
  31.     }

  32.     /**
  33.      * 记得在销毁的时候让播放的视频终止
  34.      */
  35.     @Override
  36.     public void onDestroy() {
  37.         super.onDestroy();
  38.         if (customVideoView != null) {
  39.             customVideoView.stopPlayback();
  40.         }
  41.     }
  42. }
复制代码


4.界面布局

  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2.     android:layout_width="match_parent"
  3.     android:layout_height="match_parent">

  4.     <android.support.v4.view.ViewPager
  5.         android:id="@+id/vp"
  6.         android:layout_width="match_parent"
  7.         android:layout_height="match_parent"></android.support.v4.view.ViewPager>

  8.     <LinearLayout
  9.         android:layout_width="wrap_content"
  10.         android:layout_height="wrap_content"
  11.         android:layout_alignParentBottom="true"
  12.         android:layout_centerHorizontal="true"
  13.         android:layout_marginBottom="130dp"
  14.         android:orientation="horizontal">

  15.         <ImageView
  16.             android:id="@+id/iv1"
  17.             android:layout_width="10dp"
  18.             android:layout_height="10dp"
  19.             android:src="@mipmap/dot_focus" />

  20.         <ImageView
  21.             android:id="@+id/iv2"
  22.             android:layout_width="10dp"
  23.             android:layout_height="10dp"
  24.             android:layout_marginLeft="10dp"
  25.             android:src="@mipmap/dot_normal" />

  26.         <ImageView
  27.             android:id="@+id/iv3"
  28.             android:layout_width="10dp"
  29.             android:layout_height="10dp"
  30.             android:layout_marginLeft="10dp"
  31.             android:src="@mipmap/dot_normal" />
  32.     </LinearLayout>

  33.     <Button
  34.         android:id="@+id/bt_start"
  35.         android:layout_width="wrap_content"
  36.         android:layout_height="wrap_content"
  37.         android:layout_alignParentBottom="true"
  38.         android:layout_centerHorizontal="true"
  39.         android:layout_marginBottom="50dp"
  40.         android:background="@mipmap/bt_start"
  41.         android:textColor="@android:color/white"
  42.         android:visibility="gone" />

  43. </RelativeLayout>
复制代码
5.给界面添加Fragment

  1. package cn.bluemobi.dylan.welcomevideopager;

  2. import android.os.Bundle;
  3. import android.support.v4.app.Fragment;
  4. import android.support.v4.app.FragmentManager;
  5. import android.support.v4.app.FragmentPagerAdapter;
  6. import android.support.v4.view.ViewPager;
  7. import android.support.v7.app.AppCompatActivity;
  8. import android.view.View;
  9. import android.widget.Button;
  10. import android.widget.ImageView;

  11. import java.util.ArrayList;
  12. import java.util.List;

  13. public class MainActivity extends AppCompatActivity {
  14.     private ViewPager vp;
  15.     private ImageView iv1;
  16.     private ImageView iv2;
  17.     private ImageView iv3;
  18.     private Button bt_start;
  19.     private List<Fragment> fragments;

  20.     private void assignViews() {
  21.         vp = (ViewPager) findViewById(R.id.vp);
  22.         iv1 = (ImageView) findViewById(R.id.iv1);
  23.         iv2 = (ImageView) findViewById(R.id.iv2);
  24.         iv3 = (ImageView) findViewById(R.id.iv3);
  25.         bt_start = (Button) findViewById(R.id.bt_start);
  26.     }

  27.     @Override
  28.     protected void onCreate(Bundle savedInstanceState) {
  29.         super.onCreate(savedInstanceState);
  30.         setContentView(R.layout.activity_main);
  31.         assignViews();
  32.         initData();
  33.         initView();

  34.     }

  35.     /**
  36.      * 初始化数据,添加三个Fragment
  37.      */
  38.     private void initData() {
  39.         fragments = new ArrayList<>();

  40.         Fragment fragment1 = new GuildFragment();
  41.         Bundle bundle1 = new Bundle();
  42.         bundle1.putInt("index", 1);
  43.         fragment1.setArguments(bundle1);
  44.         fragments.add(fragment1);

  45.         Fragment fragment2 = new GuildFragment();
  46.         Bundle bundle2 = new Bundle();
  47.         bundle2.putInt("index", 2);
  48.         fragment2.setArguments(bundle2);
  49.         fragments.add(fragment2);

  50.         Fragment fragment3 = new GuildFragment();
  51.         Bundle bundle3 = new Bundle();
  52.         bundle3.putInt("index", 3);
  53.         fragment3.setArguments(bundle3);
  54.         fragments.add(fragment3);
  55.     }

  56.     /**
  57.      * 设置ViewPager的适配器和滑动监听
  58.      */
  59.     private void initView() {
  60.         vp.setOffscreenPageLimit(3);
  61.         vp.setAdapter(new MyPageAdapter(getSupportFragmentManager()));
  62.         vp.addOnPageChangeListener(new MyPageChangeListener());
  63.     }

  64.     /**
  65.      * ViewPager适配器
  66.      */
  67.     private class MyPageAdapter extends FragmentPagerAdapter {


  68.         public MyPageAdapter(FragmentManager fm) {
  69.             super(fm);
  70.         }

  71.         @Override
  72.         public Fragment getItem(int position) {
  73.             return fragments.get(position);
  74.         }

  75.         @Override
  76.         public int getCount() {
  77.             return fragments.size();
  78.         }
  79.     }

  80.     /**
  81.      * ViewPager滑动页面监听器
  82.      */
  83.     private class MyPageChangeListener implements ViewPager.OnPageChangeListener {
  84.         @Override
  85.         public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

  86.         }

  87.         /**
  88.          * 根据页面不同动态改变红点和在最后一页显示立即体验按钮
  89.          *
  90.          * @param position
  91.          */
  92.         @Override
  93.         public void onPageSelected(int position) {
  94.             bt_start.setVisibility(View.GONE);
  95.             iv1.setImageResource(R.mipmap.dot_normal);
  96.             iv2.setImageResource(R.mipmap.dot_normal);
  97.             iv3.setImageResource(R.mipmap.dot_normal);
  98.             if (position == 0) {
  99.                 iv1.setImageResource(R.mipmap.dot_focus);
  100.             } else if (position == 1) {
  101.                 iv2.setImageResource(R.mipmap.dot_focus);
  102.             } else {
  103.                 iv3.setImageResource(R.mipmap.dot_focus);
  104.                 bt_start.setVisibility(View.VISIBLE);
  105.             }
  106.         }

  107.         @Override
  108.         public void onPageScrollStateChanged(int state) {

  109.         }
  110.     }
  111. }
复制代码


三.下载地址:

游客,如果您要查看本帖隐藏内容请回复


Android酷炫欢迎页播放视频,仿蚂蜂窝自由行和慕课网源码下载
http://bbs.jiandaima.com/thread-733-1-1.html


捡代码论坛-最全的游戏源码下载技术网站! - 论坛版权郑重声明:
1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
2、本站所有主题由该帖子作者发表,该帖子作者与捡代码论坛-最全的游戏源码下载技术网站!享有帖子相关版权
3、捡代码论坛版权,详细了解请点击。
4、本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,不存在任何商业目的与商业用途。
5、若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。 我们不承担任何技术及版权问题,且不对任何资源负法律责任。
6、如无法链接失效或侵犯版权,请给我们来信:jiandaima@foxmail.com

回复

使用道具 举报

0

主题

206

回帖

1033

积分

金牌会员

Rank: 6Rank: 6

积分
1033
发表于 2016-11-15 10:26:18 | 显示全部楼层
登录可见评论
回复

使用道具 举报

0

主题

7

回帖

40

积分

新手上路

Rank: 1

积分
40
发表于 2016-12-10 22:05:05 | 显示全部楼层
登录可见评论
回复

使用道具 举报

0

主题

21

回帖

57

积分

注册会员

Rank: 2

积分
57
发表于 2017-1-12 16:43:21 | 显示全部楼层
登录可见评论
回复

使用道具 举报

0

主题

9

回帖

216

积分

中级会员

Rank: 3Rank: 3

积分
216
发表于 2017-2-24 16:07:43 | 显示全部楼层
登录可见评论
回复

使用道具 举报

0

主题

8

回帖

29

积分

新手上路

Rank: 1

积分
29
发表于 2017-5-4 20:11:14 | 显示全部楼层
登录可见评论
回复

使用道具 举报

0

主题

6

回帖

42

积分

新手上路

Rank: 1

积分
42
发表于 2017-5-4 22:21:16 | 显示全部楼层
登录可见评论
回复

使用道具 举报

0

主题

17

回帖

98

积分

注册会员

Rank: 2

积分
98
发表于 2017-5-6 12:53:04 | 显示全部楼层
登录可见评论
回复

使用道具 举报

0

主题

7

回帖

77

积分

注册会员

Rank: 2

积分
77
发表于 2017-8-3 17:03:16 | 显示全部楼层
登录可见评论
回复

使用道具 举报

0

主题

8

回帖

87

积分

注册会员

Rank: 2

积分
87
发表于 2017-12-29 18:00:17 | 显示全部楼层
登录可见评论
回复

使用道具 举报

*滑块验证:
您需要登录后才可以回帖 登录 | 立 即 注 册

本版积分规则

技术支持
在线咨询
QQ咨询
3351529868

QQ|手机版|小黑屋|捡代码论坛-专业源码分享下载 ( 陕ICP备15015195号-1|网站地图

GMT+8, 2025-1-22 21:08

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表