开发之前需要考虑系统的差异性,比如ios手机没有回退键,所以在开发时一定要考虑二级界面需要有回退键,否则ios的手机就会陷入到这个页面出不去了。
安卓系统有回退键,针对这个情况需要要求用户在3秒钟之内连续按回退键两次才退出系统,以此防止用户误按回退键,具体代码实现如下:

[mw_shl_code=javascript,true]page.on("back", function(){
    if (canBack) {
        global.exit();
    } else {
        nf.toast("再按一次退出优酷");
        canBack = true;
        delay3.start();
    }
});

var delay3 = mm("do_Timer");
delay3.delay = 3000;
delay3.interval = 1000;
delay3.on("tick", function(){
    this.stop();
    canBack = false;
});[/mw_shl_code]

仿优酷视频实现了四个主界面,页面之间可以通过左右滑动页面来切换页面,也可以通过点击底部按钮实现页面间的切换,并且底部按钮的颜色也会随着页面的切换而改变。此功能通过slideview组件实现,效果图片如下:

底部变化:

代码实现如下:

[mw_shl_code=javascript,true]

function subChange(num,button,imgs,lbs)
{
        var strings = ["下载","频道","订阅","我的"];
        button.text = strings[num];
        var url = [
                   "source://image/main/shouye",
                   "source://image/main/pindao",
                   "source://image/main/dingyue",
                   "source://image/main/wode"
                   ];
        for(var i = 0 ; i < 4 ; i++)
    {
            imgs.source = url;
            lbs.fontColor = "222222FF";
    }
    imgs[num].source += "b";
    lbs[num].fontColor = "0080FFFF";
    for(var i = 0 ; i < 4 ; i++)
    {
            imgs.source += ".png";
    }
        img.visible = false;
        bt.visible = false;
}

function indexChange(num,sv,button,imgs,lbs,img,bt)
{
        sv.set({index: num});
    sv.refreshItems();
    subChange(num,button,imgs,lbs);
}

do_button.on("touch",function(data, e){
        if(do_button.text == "下载")
        {
                app.openPage("source://view/download.ui","");
        }
});

//点击底部按钮实现主界面以及底部图片颜色的切换
var action_imgs = [ui("img_0"), ui("img_1"), ui("img_2"), ui("img_3")];
var action_lbs = [ui("lb_0"), ui("lb_1"), ui("lb_2"), ui("lb_3"),];

do_slideview_1.bindItems(listdata );

listdata.addData([
    {template : 0},
    {template : 1},
    {template : 2},
    {template : 3}
]);
do_slideview_1.refreshItems({});

var shouye = ui("shouye");
shouye.on("touch",function(data, e){
        indexChange(0,do_slideview_1,do_button,action_imgs,action_lbs,imageview,do_button_3);
});

var pindao = ui("pindao");
pindao.on("touch",function(data, e){
        indexChange(1,do_slideview_1,do_button,action_imgs,action_lbs,imageview,do_button_3);
});

var dingyue = ui("dingyue");
dingyue.on("touch",function(data, e){
        indexChange(2,do_slideview_1,do_button,action_imgs,action_lbs,imageview,do_button_3);
});

var wode = ui("wode");
wode.on("touch",function(data, e){
        indexChange(3,do_slideview_1,do_button,action_imgs,action_lbs,imageview,do_button_3);
});

//滑动主界面实现底部图片的切换
do_slideview_1.on("indexChanged",function(data, e){
        subChange(data,do_button,action_imgs,action_lbs);
});

[/mw_shl_code]

首页海报之间的切换和页面间切换类似,但海报间切换还实现了自动定时切换的功能,每三秒钟切换一次,时间控制由do_timer来实现,在使用这个组件时,时间段不能是100,否则ios系统将会有不兼容的问题,图片及代码如下所示:

图片:

代码:

[mw_shl_code=javascript,true]
var ind = 0;
timer.delay = 0;
timer.interval = 1000;
timer.start({});
timer.on("tick", function(){
        DURATION++;
    if(DURATION == 3){
            ind =(ind+1)%4
            movieview.set({index: ind});
            movieview.refreshItems();
            DURATION = 0;
    }
});[/mw_shl_code]

点击主界面的左上角的下载按键后,进入下载界面,点击下载后应用将从网上下载另个图片的海报来取代原海报,下载的进度通过进度条来显示,下载功能通过http组件的download方法实现,进度条通过do_progressbar组件实现,其效果图及代码实现如下:
效果:

代码:
[mw_shl_code=javascript,true]
var http = mm("do_Http");
http.timeout = 30000;
http.contentType = "application/json";
http.url = "http://h.hiphotos.baidu.com/baike/c0%3Dbaike60%2C5%2C5%2C60%2C20%3Bt%3Dgif/sign=88e9903f8735e5dd8421ad8d17afcc8a/f9198618367adab48dc66b2e89d4b31c8701e44d.jpg";

http.on("success", function(data) {
        do_imageview_1.source="data://xiazai.png";
        do_button_2.text = "下载成功";
});

http.on("progress", function(data) {
    do_ProgressBar_0.progress = data.currentSize * 100 / data.totalSize;
    lb_progress.text = data.currentSize * 100 / data.totalSize + "%";
});

do_button_2.on("touch",function(data, e){
        http.download("data://xiazai.png");
});[/mw_shl_code]

右上角有三个按钮点击左数第一个按钮之后将弹出一个查找界面,查找界面的搜索框由textfield组件实现。

点击第二个按钮之后将弹出扫描二维码的界面,该界面实现了扫描二维码的功能,成功之后提示用户扫描成功,二维码由do_BarcodeView组件实现,实现图片和实现代码如下所示:

代码:

[mw_shl_code=javascript,true]var nf = sm("do_Notification");

//根据ID获取BarcodeView实例对象;
var barcode = ui("do_BarcodeView_1");
start();

function start(){
        //开始启动扫描
        barcode.start(function(data, e) {
                //扫描成功,执行回调函数
                var result = JSON.stringify(data);  
                nf.alert("扫描二维码成功!", "完成")
        });
}

var btn = ui("btn_restart");
btn.on("touch", function(data, e) {
        start();
})
[/mw_shl_code]

点击第三个按钮之后,界面将弹出一个图片,再按一次该按钮后,图片消失,效果如下:


视频播放功能
点击首页的任意一张海报就进入到视频播放界面,点击播放按键后将播放视频,此功能由do_VideoView组件实现,效果和代码实现如下:

代码:

[mw_shl_code=javascript,true]var page = sm("do_Page");
var app = sm("do_App");
var do_VideoView_1 = ui("do_VideoView_1");
var do_Button_1 = ui("do_Button_1");
var do_Button_2 = ui("do_Button_2");
var do_Button_3 = ui("do_Button_3");

page.on("back", function(){ app.closePage() });
ui("action_back").on("touch", function(){ app.closePage() });

do_Button_1.on("touch", function(data, e) {
        if(do_Button_1.text == "播放")
        {
                do_VideoView_1.play(0);
                do_Button_1.text = "暂停";
        }
        else if(do_Button_1.text == "暂停")
        {
                do_VideoView_1.pause();
                do_Button_1.text = "继续";
        }
        else if(do_Button_1.text == "继续")
        {
                do_VideoView_1.resume();
                do_Button_1.text = "暂停";
        }
                
});

do_Button_2.on("touch", function(data, e) {
        do_Button_1.text = "播放";
        do_VideoView_1.stop();
});[/mw_shl_code]

点击“戳一下,你喜欢看的都在这里了”按钮,主页面会直接跳到订阅页面。此功能的实现依赖于页面之间的数据交换,利用page组件在index页面的逻辑代码中定义一个event1事件,在shouye页面的逻辑代码中调用page组件的fire函数来触发event1事件。
效果图如下:

逻辑代码如下:
index页面:

[mw_shl_code=javascript,true]page.on("event1", function(data, e) {
        indexChange(2,do_slideview_1,do_button,action_imgs,action_lbs,imageview,do_button_3);
});[/mw_shl_code]

shouye页面:

[mw_shl_code=javascript,true]do_Button_0.on("touch",function(data, e)
{
        page.fire("event1","");
});[/mw_shl_code]

JavaScript使用DeviceOne开发实战(四)仿优酷视频应用的更多相关文章

  1. JavaScript使用DeviceOne开发实战(三)仿微信应用

    这是一个系列的文档,长期目标是利用DeviceOne开发一些目前使用广泛的优质手机应用,我们会最大化的实现这些应用的每一个功能和细节,不只停留在简单的UI模仿和Demo阶段,而是一个基本可以使用的实际 ...

  2. JavaScript使用DeviceOne开发实战(一) 配置和起步

    2015 年 9 月 底,DeviceOne Release发布.至此,DeviceOne 基本完成了对多端的支持.基于 DeviceOne 可以: HTML5.Android.iOS.Windows ...

  3. JavaScript使用DeviceOne开发实战(五)仿ZAKER应用

    关于index底下切换的的组件,可以用ViewShower实现,详见: do_ViewShower http://bbs.deviceone.net/forum.php?mod=viewthread& ...

  4. JavaScript使用DeviceOne开发实战(二) 生成调试安装包

    生成调试安装包 首先需要说明的是,这个步骤并不是每次调试App都必须的,大部分情况生成一次调试安装包,安装到手机上之后就可以忽略整个这个步骤.因为调试安装包包含了很多原生组件,都是可以定制勾选的,如果 ...

  5. JavaScript使用DeviceOne开发实战(六)点墨真实案例

    qq群里的yan用户开发的App,基本完工大家可以看看 安装二维码是 QQ群:365443130

  6. 仿优酷项目—orm

    仿优酷项目 一.ORM介绍 对象关系映射,把数据库中的表数据(表名.表记录.字段)全部映射到python中. ​ mysql: python: ​ 表名 ---->类名 ​ 记录 ----> ...

  7. 仿优酷Android客户端图片左右滑动(自动滑动)

    最终效果: 页面布局main.xml: <?xml version="1.0" encoding="utf-8"?> <LinearLayou ...

  8. 高仿优酷Android客户端图片左右滑动(自动切换)

    本例是用ViewPager去做的实现,支持自动滑动和手动滑动,不仅优酷网,实际上有很多商城和门户网站都有类似的实现: 具体思路: 1. 工程中需要添加android-support-v4.jar,才能 ...

  9. ViewPager实现滑屏切换页面及动画效果(仿优酷客户端)

     找了许多实现该功能的例子,但效果都不很理想,于是自己结合网上的资源及自己的总结,整理了一下,发出来,供大家参考.这个是自己做的,仿优酷客户端的. 先看效果: ****************** ...

随机推荐

  1. C语言实现 字符串过滤并修改并返回个数

    基本问题:给定一个strContent,strWord,使用strWord 匹配strContent,匹配成功,将匹配部分全部替换为‘*’ ,并返回匹配成功个数.注意不能使用库函数. 例如:strCo ...

  2. .Net WinForm下配置Log4Net(总结不输出原因)

    最近做一个winform项目,配置了Log4net 但是总是不能输出,搜索了很多文章加上自己的探索发现自己在项目中添加的 Log4Net.config 生成时没有被复制到Debug文件夹下, 所以程序 ...

  3. My97Datepicker 去掉 “不合法格式或超期范围”自动纠错限制

    官网上,纠错有以下三种,如日期格式不对,或超期,则必须纠错过后,才能继续操作, 但有时,可能允许出错,需要把纠错功能去掉,则可以设置errDealMode = 3,这种模式是官网说没有的, 但能够去掉 ...

  4. 通过通知监听键盘的状态来改变View的位置

    #import "ViewController.h" @interface ViewController ()<UITextFieldDelegate>{    UIV ...

  5. Socket通信基本原理

    Http通信: http连接使用的是“请求—响应方式”,即在请求时建立连接通道,当客户端向服务器发送请求后,服务器端才能向客户端返回数据. Socket通信: Socket通信则是在双方建立起连接后就 ...

  6. 使用.NET读取exchange邮件

    公司有个第3方的系统,不能操作源码修改错误捕获,但是错误会发一个邮件出来,里面包含了主要的信息.于是想从邮件下手,提取需要的数据 开始考虑使用的是exchange service,主要参考http:/ ...

  7. 封装ios静态库碰到的一些问题(一)

    封装IOS动态库,碰到的第一个问题,就是资源文件的问题,如果将你的程序封装成为静态库,那么静态库中不会包含资源文件和xib文件,这个时候就需要自己封装bundle文件了,而笔者开发环境默认是xcode ...

  8. 在DW 5.5+PhoneGap+Jquery Mobile下搭建移动开发环境

    移动设备应用开发有多难,只要学会HTML5+Javascript就可以.用Dreamweaver5.5+PhoneGap+Jquery Mobile搭建移动开发环境,轻轻松松开发你自己的应用.让你用普 ...

  9. java 单利模式

    首先何为单利模式: 单利模式即多次调用同一个对象的时候,只有一个实例(这里所谓的实例就是,假如创建了两个对象,它们的hashCode相同) 下面是相关代码: 1 创建一个对象Singleton类 pa ...

  10. (转)深度分析Linux下双网卡绑定七种模式

    现在一般的企业都会 使用双网卡接入,这样既能添加网络带宽,同时又能做相应的冗余,可以说是好处多多.而一般企业都会使用linux操作系统下自带的网卡绑定模式,当然现在 网卡产商也会出一些针对window ...