一步一步实现视频播放器client(二)
实现主体界面:
222.png (64.46 KB, 下载次数: 0)
下载附件 保存到相冊
比較常见的一种布局。以下几个button。点击后。切换到对应的界面,能够使用tabhost+RadioGroup来实现,或者其它的比方fragmentTabhost+fragment等。实现方式有好几种。本app是非常久之前做的,採用老方法tabhost+RadioGroup来实现的。界面底部是RadioGroup,里面放了4个radiobutton,4个button切换时候,分别切换显示4个不同的activity,button上面显示部分是另外一个activity。
MainActivity的主代码例如以下:
private static final String HOME = "home";
private static final String HOT = "hot";
private static final String TJ = "tj";
private static final String LOCAL = "local";
private RadioGroup rGroup; //这里用RadioGroup来代替TabWidget,更加方便我们设计控件的样式,用于底部4个button
private TabHost tabHost; //像一个容器,把我们须要展示的activity放进去,依据我们须要进行显示
private TabSpec tabSpec; //各个选项卡
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
setLister();
}
private void setLister() { //绑定事件
rGroup.setOnCheckedChangeListener(this);
}
private void initView() //初始化view
{
rGroup = (RadioGroup) findViewById(R.id.RadioGroup);
tabHost = this.getTabHost(); //从TabActivity中获取一个tabHost对象。由于我们继承了TabActivity,它已经获取了tabHost。我们不用再用findViewById
/**
* 获取各个选项卡,而且把对应的activity装进去,能够加一个或者多个,更具自己须要加入,activity须要我们自己创建,记住在配置文件中面进行配置
*/
tabSpec = tabHost.newTabSpec(HOT).setIndicator(HOT)
.setContent(new Intent(this, HotActivity.class)); //HotActivity,显示热门电影界面,刚进入时候,显示得第一个界面
tabHost.addTab(tabSpec);
tabSpec = tabHost.newTabSpec(TJ).setIndicator(TJ)
.setContent(new Intent(this, RecommendActivity.class)); //推荐界面
tabHost.addTab(tabSpec);
tabSpec = tabHost.newTabSpec(HOME).setIndicator(HOME)
.setContent(new Intent(this, AllVideoActivity.class));
//所有电影界面
tabHost.addTab(tabSpec);
tabSpec = tabHost.newTabSpec(LOCAL).setIndicator(LOCAL)
.setContent(new Intent(this, LocalVideoActivity.class));
//本地视频
tabHost.addTab(tabSpec);
}
//点击以下5个Radiobutton,点击时候触发这里的事件,分别切换到对应的界面
public void onCheckedChanged(RadioGroup group, int checkedId) {
switch (checkedId) {
case R.id.hot_id:
tabHost.setCurrentTab(0); //跳转到热门界面
break;
case R.id.tuijian_id:
tabHost.setCurrentTab(1); //跳转推荐界面
break;
case R.id.home_id:
tabHost.setCurrentTab(2); //跳转所有电影界面
break;
case R.id.local_id:
tabHost.setCurrentTab(3); //跳转本地视频
break;
}
}
MainActivit的布局文件例如以下:
<?
xml version="1.0" encoding="utf-8"?>
<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/tabhost" //该id名字必须这样写,不能变,TabActivity会依据此id获取tabhost对象
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal" >
<TabWidget //该控件尽管是影藏的,可是必需要写出来。id也必须入下。不能改变。不然代码里面用tabhost获取tabTabSpec会出错。他显示时候。显示在界面的顶端,不是我们需要的。我们把它影藏,用以下的RadioGroup来取代
android:id="@android:id/tabs"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:visibility="gone" >
</TabWidget>
<RelativeLayout //使用相对布局,方便radiogroup能够显示究竟部,还有能够使类容不被以下的4个button挡住
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<FrameLayout //这个是用来放置其它activity的。id也必须这样,不能任意变。
就是切换时候的那4个activity
android:id="@android:id/tabcontent"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_above="@id/RadioGroup" > //这里设置位置在Radiogroup上面,放置部分内容被4个button挡住
</FrameLayout>
<RadioGroup //放置底部4个radiobutton
android:id="@id/RadioGroup"
android:layout_width="fill_parent"
android:layout_height="50dp"
android:layout_alignParentBottom="true" //放置在父控件的最以下
android:gravity="bottom"
android:orientation="horizontal" >
<RadioButton
android:paddingTop="5dp"
android:id="@id/hot_id" //这里名字随便取的。大家请依照规范命名。这里id是放在ids里面的,也能够直接用+号形式直接写
style="@style/main_radio_botton" //4个button属性同样的部分,我们提出去。放到style文件中面,达到公用
android:layout_width="wrap_content"
android:layout_height="fill_parent"
android:layout_weight="1" //设置权重,保重4个button的宽度一致
android:background="@drawable/bar_selector"
//这个比較经常使用,设置一个selector的xml文件,点击时候,切换背景。
android:checked="true" //表示改radiobutton是选中状态,上面设置了selector。它就能够更具这个状态。显示对应的背景了
android:drawableTop="@drawable/main_bt_ico_hot"
//看意思能看出来。在控件顶部放一个图片,当然一次还能够放其它位置
android:gravity="center"
android:text="@string/main_bt_hot"
android:textSize="12sp" />
</RadioGroup>
</RelativeLayout>
</TabHost>
除了MainActivity界面,我们还须要4个activity。上面有写,来先看看第一个界面HotActivity的布局文件
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="#000000"
android:orientation="vertical" >
<FrameLayout //最顶部标题栏部分,由于非常多时候,它左边和右边都有对应的button,比方返回键什么的。所以用FrameLayout 来做。通过控件的属性
android:layout_gravity="xxxx",能够方便的把控件显示在中间,左边,右边,各种居中等
android:layout_width="fill_parent"
android:layout_height="40dp"
android:background="@drawable/test_title_bg" >
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center" //控件显示在中间。显示我们的app名字
android:text="@string/app_name"
android:textColor="#ffffff"
android:textSize="18sp" />
</FrameLayout>
<HorizontalScrollView //标题栏以下是一排button。应为比較多。能够 滑动。所以使用该控件,实现。左右滑动
android:id="@+id/hscroll"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:scrollbars="none" >
<RadioGroup //这里还是使用它来实现点击切换效果,主要是为了使用它的checked属性。非常方便的变换,点击button后,切换背景
android:id="@+id/bar_rg"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center"
android:orientation="horizontal" >
<RadioButton
android:id="@+id/bar_rd1"
style="@style/main_radio_botton"
android:layout_width="60dp"
android:layout_height="35dp"
android:layout_marginBottom="3dp"
android:layout_marginLeft="5dp"
android:layout_marginTop="3dp"
android:background="@drawable/sc_bar_selector"
android:checked="true"
android:gravity="center"
android:paddingBottom="3dp"
android:text="@string/hot_text_rd" />
</RadioGroup>
</HorizontalScrollView>
<FrameLayout
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<LinearLayout //我们的数据是用listview来显示的。这里每一个button相应一个listview。在界面里面。我们动态加入到该linearlayout上面
详细写代码时候,大家会清楚的,用多个listview来显示不同类型的数据。通过显示影藏。来显示不同的数据,而不会又一次刷新数据
android:id="@+id/list_lin"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="#ffffff"
android:orientation="vertical" >
</LinearLayout>
<include //自己定义的一个progress,一个转圈圈的view,提示用户当前在载入数据。这个view提出来,写在一个xml里面,便于其它界面使用。公用view,大家都能够单独提出来,在用include 增加
android:id="@+id/pb"
layout="@layout/progress_bar" />
</FrameLayout>
</LinearLayout>
为了使我们的额代码看起来比較统一,我们创建一个包com.hck.videoplayer.interfaces。在里面我们新建一个借口类:
public interface BaseMethod {
public void initView(); //初始化数据
public void getData(); //从server获取数据
public void updateUi(); //更新界面
public void setDataToServer(); //发送数据到server
public void initData(); //初始化数据
}
源代码地址:http://pan.baidu.com/s/1eQirxuU
我的贴吧:http://tieba.baidu.com/f?kw=android%E5%BC%80%E5%8F%91%E5%AD%A6%E4%B9%A0&ie=utf-8
有问题能够这里来提问,大家相互交流,尽量回答大家问题。
有写属性数据各个界面可能公用,我们在ui包下创建一个名字叫BaseActivity的activity,继承activity,后面,公用的数据。我们就放在里面了。
然后在使用的时候。我们其它的activity都继承该BaseActivity,然后都实现 BaseMethod接口
好了,本片几乎相同这样了。时间有限。能力有限,非常多地方没写到位。可能有错误的地方,请大家见谅,文章,紧供參考。
须要的,大家能够參考下,不喜忽喷,谢谢
一步一步实现视频播放器client(二)的更多相关文章
- Android开发学习之路--基于vitamio的视频播放器(二)
终于把该忙的事情都忙得差不多了,接下来又可以开始good good study,day day up了.在Android开发学习之路–基于vitamio的视频播放器(一)中,主要讲了播放器的界面的 ...
- (转)薛飞 基于VLC的Unity视频播放器(二)
转自:http://www.manew.com/thread-144229-1-1.html 留个记录.
- SmartMS如何使用二次验证码/虚拟MFA/两步验证/谷歌身份验证器?
一般点账户名——设置——安全设置中开通虚拟MFA两步验证 具体步骤见链接 SmartMS如何使用二次验证码/虚拟MFA/两步验证/谷歌身份验证器? 二次验证码小程序于谷歌身份验证器APP的优势 1.无 ...
- 一步一步搭建基于ffmpeg和sdl2的流媒体播放器
一. 背景: 一步一步从资料收集.技术选型.代码编写.性能优化,动手搭建一款支持rtsp.rtmp等常用流媒体格式的视频播放器,ffmpeg用于流媒体解码,sdl2用于视频画面渲染和声音播放. 二. ...
- 一步一步自定义SpringMVC参数解析器
随心所欲,自定义参数解析器绑定数据. 题图:from Zoommy 干货 SpringMVC解析器用于解析request请求参数并绑定数据到Controller的入参上. 自定义一个参数解析器需要实现 ...
- 一步一步学Silverlight 2系列(18):综合实例之RSS阅读器
一步一步学Silverlight 2系列(18):综合实例之RSS阅读器 概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支 ...
- Mybatis源码解析,一步一步从浅入深(三):实例化xml配置解析器(XMLConfigBuilder)
在上一篇文章:Mybatis源码解析,一步一步从浅入深(二):按步骤解析源码 ,中我们看到 代码:XMLConfigBuilder parser = new XMLConfigBuilder(read ...
- C语言基于GTK+Libvlc实现的简易视频播放器
小编心语:现下,各种视频播放软件层出不穷,竞争也越演越烈,不知道大家有木有这个想法,小编有时在想能不能做一款属于自己的视频播放器呢~小编特意去实验楼,整理出了这篇关于如何实现简易视频播放器的博文.简易 ...
- 建站技能get(1)— Asp.net MVC快速集成ckplayer网页视频播放器
故事背景大概是这样的,我厂两年前给山西晋城人民政府做了一个门户网站(地址:http://jccq.cn/),运行了一年多固若金汤,duang的有一天市场部门过来说,新闻管理模块带视频的内容播放不了了. ...
随机推荐
- 【BZOJ4481&JSOI2015】非诚勿扰(数学期望)
听说JSOI有版权问题就不放图了 如果前面的文章里的图需要删掉请通知我 题意:有一些女的要挑一些男的,挑中的几率均为p.一个男的可以无限次被挑中.若女a选中男b,女c选中男d,a<c,b> ...
- LOJ#2086. 「NOI2016」区间
$n \leq 500000$个区间,从中挑出一些,使得至少有一个点被$m$个选中区间包含,且选中区间长度的极差最小. 区间题死脑筋晚期:把区间按左端点排序,然后右端点用个优先队列来弹,然后需要维护下 ...
- 长沙理工校赛I题题解-连续区间的最大公约数
题目来源https://www.nowcoder.com/acm/contest/96/I 解题前们需要先知道几个结论: 首先,gcd是有区单调性的: gcd(L,R)>=gcd(L,R+d) ...
- android中提示&对话框----Toast
Toast(吐司) 一.Toast吐司是一种消息提示框,在手机屏幕中显示一个消息提示框,没有任何按钮,也不会获得焦点,一段时间后自动消失,常常在调试的时候用的较多. 二.使用 (1)直接调用Toast ...
- VIM的修炼等级
用vim 快两年了 看过教程也不少,总的来说还是得自己多练习,当自己觉得有需要的时候,再添加功能.这里分享个看过的最好的教程,出自贴吧的某个朋友,写的很好 零 学会盲打 壹 配置文件先从最简开始,在 ...
- composer update/require slow when enable XDebug in CLI environment
Recently I find there will be some issue to use composer command, which seems too slow to finish. Af ...
- #译# Core Data概述 (转)
昨晚熬夜看发布会(本以为屌丝终于能买得起苹果了,谁知道...),因为看不了视频直播,所以就正好有空就把www.objc.io最新的一篇文章翻译了一下,同时感谢CocoaChina翻译组提供校对,以下为 ...
- 【ActiveMQ】1.下载安装启动使用
官网下载:http://activemq.apache.org/activemq-5121-release.html 官网指导文档:http://activemq.apache.org/version ...
- xamarin.ios 本地通知推送
由于ios10版本以后UILocalNotification被标为弃用了,所以要添加新的本地通知推送功能,下面提供一些代码参考. 一.先在AppDelegate.cs上注册本地通知推送功能. publ ...
- js右下角弹窗代码(实测好用)
实测好用的js右下角弹窗代码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "htt ...