HarmonyOS实战—影视类卡片应用(一)

简介: HarmonyOS实战—影视类卡片应用(一)

HarmonyOS实战


影视类卡片应用实战

在前面,博主详细介绍了HarmonyOS原子化服务的优点,通过卡片式操作,我们可以快速找到我们想要的功能模块。


而在实际的用户体验中,比如影视类用户,有这么一群人,他们只关注最近的影视剧,而不在乎以前的影视剧。


这种情况下,普通的视频应用功能太过多,往往并不方便这些用户的查找。我们可以通过原子化服务创建一个近一个月的影视剧服务,来满足这群用户。


这样,用户在鸿蒙手机上打开卡片就能快速浏览近一个月的视频,而不必去搜索框打字找寻,或者翻页查找,大大方便了用户的体验效果。(顺便去掉广告哦)


那么,今天博主就通过原子化服务开发一个影视剧类的App服务。


swiper选项卡推荐功能

首先,对于大多数的影视剧App来说,其顶部都有一个swiper组件,也就是自动浏览推荐窗口,推荐大家视频。


所以,我们需要通过swiper组件来实现影视剧的推荐。index.hml代码如下:

<div class="container">
    <swiper class="swiper" id="swiper" index="{{ swiper_index }}" indicator="true" duration="1000" autoplay="true" loop="true">
        <div for="{{responseData.vipList}}" onclick="swiper_onClick({{$item}})" data="{{$item}}">
            <image class="swiper_image" src="{{$item.img_url}}"/>
            <text class="swiper_text">{{$item.title}}</text>
        </div>
    </swiper>
</div>


其中,有3个数据需要注意:

数据 意义
responseData.vipList 网络获取的JSON数据(下面会介绍网络数据的获取)

swiper_onClick

用户点击肯定是需要观看视频的,这是一个点击事件跳转到视频详情页面

autoplay与loop 自动循环播放swiper推荐

运行之后,显示的效果如下:


网络数据请求

在鸿蒙开发中,网络数据请求非常简单,主要会用到@system.fetch模块。所以在Js文件中,进行网络请求时,先导入该模块。(index.js)

import fetch from '@system.fetch';
export default {
    data: {
        title: "",
        url: "https://liyuanjing-1300376177.cos.ap-shanghai.myqcloud.com/viptopmodel.json",
        responseData: '正在加载中',
        swiper_index: 0,
    },
    //界面初始化网络JSON数据获取
    fetch: function () {
        var that = this;
        fetch.fetch({
            url: that.url,
            success: function (response) {
                console.info("网络请求成功");
                that.responseData = JSON.parse(response.data);
                console.info(that.responseData.vipList[0].title);
            },
            fail: function () {
                console.info("网络请求错误");
            }
        });
    },
    onInit() {
        this.fetch();
    }
}


如上面代码所示,获取网络数据的主要方法是fetch()。而因为界面首先肯定需要数据,所以必须在onInit()方法中就开始调用。


页面路由

当用户点击了swiper组件中的一个图片之后,肯定会跳转到该图片对应的视频,那么我们就需要用到鸿蒙页面路由的相关知识。示例如下(index.js):

import router from '@system.router';
export default {
  //路由跳转
    jump_router:function(item){
        router.push({
            uri: 'pages/index/playvideo/playvideo',
            params: {
                data1: encodeURIComponent(item.img_url),
                data2: encodeURIComponent(item.mp4_url),
                data3: encodeURIComponent(item.title),
            },
        });
    },
}


如上面代码所示,我们通过router.push()进行路由的跳转。当然,这里也要用到路由跳转的模块,需要先导入。


同时,因为我们的视频播放组件<video>需要2个基本的参数,也就是视频链接与视频显示的封面图,所以我们需要传递3个数据:标题,图片链接,视频链接。


标题是跳转路由详情页面需要用到的数据,并不是<video>的数据,但同样也需要。


不过,我们这里并没有跳转路由,因为swiper组件的点击事件是swiper_onClick(),我们需要通过该函数来跳转路由。代码如下:

export default {
  //滑动模块点击事件
    swiper_onClick: function (item) {
        this.jump_router(item);
    },
}


这里,之所以把跳转路由的代码独立出来,是为了减少代码的冗余,后面的list列表以及grid网格都是上面的路由跳转代码。


list列表横向视频推荐

接着,我们需要实现横向的list视频列表。读者可以自行随便打开一个影视类App,下面跟着的是不是一个横向的视频推荐模块呢?具体效果如下:


在鸿蒙原子化服务开发中,也提供了list列表组件。我们可以直接通过它来实现该样式与功能。代码如下所示(index.hml):

<div class="container">
  <!--上面的swiper代码-->
  <div style="flex-direction: row;height: 40px;">
        <text class="divi_text">猜你会追 ></text>
        <marquee class="divi_marquee">精彩的内容等着你来寻找</marquee>
    </div>
    <list class="list">
        <list-item id="listItem" for="{{responseData.vipList}}" class="list_item" onclick="list_item_onclick({{$item}})" data="{{$item}}">
            <image class="list_item_image" src="{{$item.img_url}}"/>
            <text class="list_item_text">{{$item.title}}</text>
        </list-item>
    </list>
</div>


这里的list列表很好理解,基本上与swiper组件的代码类似。需要特别注意的是我们list列表上面还有一个模块。


也就是横排文字推荐,左边的只是一个文本,而右边是一个横向滚动的文本组件<marquee>。


这里的list列表同样需要通过list_item_onclick()方法进行路由页面的跳转。具体的代码如下所示(index.js):

export default {
  //list列表点击事件
    list_item_onclick:function(item){
        this.jump_router(item);
    },
}


因为上面的路由代码已经写了,所以这里实现起来就比较简单了,只需要定义一个函数,通过jump_router()方法调用即可。


这里list列表还是使用的同一样Json数据,但原理是一样的,如果你有其他的视频接口数据,可以自行改变网址。


grid网格视频推荐

有木有发现,主流的视频App,其首页基本都是一样的。先来一个swiper组件,再是一个横向的list列表,接着就是一个grid网格视频推荐。


所以,我们这里需要实现鸿蒙系统的网格效果,鸿蒙原子化服务开发给我们提供的网格组件是:grid-container。示例如下(index.hml):

<div class="container">
  <!--上面的list,swiper代码-->
  <div style="flex-direction: row;height: 40px;">
        <text class="divi_text">重磅推荐 ></text>
        <marquee class="divi_marquee">精彩的内容等着你来寻找</marquee>
    </div>
    <grid-container for="{{responseData.vipList}}" columns="3" style="margin-top: 10px;">
        <grid-row if="{{parseInt($item.uid)%2==0}}" class="grid-row">
            <grid-col class="grid-col" span="2" onclick="grid_onclick({{$item}})">
                <image class="grid-col_image" src="{{$item.img_url}}"/>
                <text class="grid-col_text">{{$item.title}}</text>
            </grid-col>
            <grid-col class="grid-col" span="2" onclick="grid_onclick({{$item}})">
                <image class="grid-col_image" src="{{$item.img_url}}" />
                <text class="grid-col_text">{{$item.title}}</text>
            </grid-col>
        </grid-row>
    </grid-container>
</div>


运行之后,效果如下所示:

对于鸿蒙的网格组件grid-container,使用的同样是上面的JSON数据,它的点击事件是grid_onclick()方法。实现代码如下(index.js):

export default {
  //网格点击事件
    grid_onclick:function(item){
        this.jump_router(item);
    },
}


到这里,我们的影视类卡片应用的主页基本上都实现完成了。当然,对于视频类App来说,这整个页面都是可以下拉刷新的。


这会用到refresh组件,实现起来其实很简单,无非就是再调用一次fetch()函数获取一次新的json数据即可。(下次实战讲解,本篇内容有点多)


样式文件(index.css)

当然,上面那么多代码之所以搭配起来是前文显示的效果,多亏了css文件的样式调配。这里,我们就直接上代码了:

.container {
    flex-direction: column;
    margin: 10px;
}
.divi_text{
    position: absolute;
    font-size: 20px;
    margin-top: 10px;
    color: darkorange;
    margin-left: 10px;
    left: 0;
}
.divi_marquee{
    width: 130px;
    position: absolute;
    right: 0;
    font-size: 20px;
    color: darkorange;
    margin-top: 10px;
}
.list {
    font-size: 40px;
    height: 100px;
    color: #000000;
    opacity: 0.9;
    flex-direction: row;
}
.list_item{
    flex-direction: column;
    align-content: center;
    margin-top: 10px;
    margin-right: 10px;
}
.list_item_text{
    font-size: 15px;
    color: red;
    margin-top: 5px;
    align-content: center;
}
.list_item_image{
    width: 150px;
    height: 75px;
    border-radius:5px;
}
.swiper{
    height: 200px;
    indicator-bottom: 20px;
    indicator-right: 30px;
    indicator-color: #cf2411;
    indicator-size: 14px;
}
.swiper_image{
    width: 100%;
    border-radius:25px;
}
.swiper_text{
    position:absolute;
    margin-bottom: 20px;
    margin-left: 10px;
    font-size: 20px;
    color: darkturquoise;
    left:0;
    bottom:0;
}
.grid-row{
    height:100px;
    margin-left: -15px;
}
.grid-col{
    flex-direction: column;
    display: flex;
    margin-right: 10px;
    margin-left: -10px;
}
.grid-col_text{
    font-size: 15px;
    color: red;
}
.grid-col_image{
    width: 150px;
    height: 75px;
    border-radius:5px;
}


相关文章
|
11天前
「Mac畅玩鸿蒙与硬件41」UI互动应用篇18 - 多滑块联动控制器
本篇将带你实现一个多滑块联动的控制器应用。用户可以通过拖动多个滑块,动态控制不同参数(如红绿蓝三色值),并实时显示最终结果。我们将以动态颜色调节为例,展示如何结合状态管理和交互逻辑,打造一个高级的滑块控制器应用。
145 78
「Mac畅玩鸿蒙与硬件41」UI互动应用篇18 - 多滑块联动控制器
|
12天前
|
UED
「Mac畅玩鸿蒙与硬件40」UI互动应用篇17 - 照片墙布局
本篇将带你实现一个简单的照片墙布局应用,通过展示多张图片组成照片墙效果,用户可以点击图片查看其状态变化。
118 67
「Mac畅玩鸿蒙与硬件40」UI互动应用篇17 - 照片墙布局
|
2天前
|
存储 索引
「Mac畅玩鸿蒙与硬件44」UI互动应用篇21 - 随机励志语录生成器
本篇将带你实现一个随机励志语录生成器应用。用户点击按钮后,界面会随机显示一条预设的励志语录。该应用展示了如何结合数组操作、状态管理和动态更新界面内容的功能,是一个轻量级的互动应用示例。
53 21
「Mac畅玩鸿蒙与硬件44」UI互动应用篇21 - 随机励志语录生成器
|
17天前
|
存储 UED
「Mac畅玩鸿蒙与硬件37」UI互动应用篇14 - 随机颜色变化器
本篇将带你实现一个随机颜色变化器应用。用户点击“随机颜色”按钮后,界面背景会随机变化为淡色系颜色,同时显示当前的颜色代码,页面还会展示一只猫咪图片作为装饰,提升趣味性。
74 36
「Mac畅玩鸿蒙与硬件37」UI互动应用篇14 - 随机颜色变化器
|
14天前
「Mac畅玩鸿蒙与硬件38」UI互动应用篇15 - 猜数字增强版
本篇将带你实现一个升级版的数字猜谜游戏。相比基础版,新增了计分和历史记录功能,用户可以在每次猜测后查看自己的得分和猜测历史。此功能展示了状态管理的进阶用法以及如何保存和显示历史数据。
71 31
「Mac畅玩鸿蒙与硬件38」UI互动应用篇15 - 猜数字增强版
|
9天前
「Mac畅玩鸿蒙与硬件43」UI互动应用篇20 - 闪烁按钮效果
本篇将带你实现一个带有闪烁动画的按钮交互效果。通过动态改变按钮颜色,用户可以在视觉上感受到按钮的闪烁效果,提升界面互动体验。
60 19
「Mac畅玩鸿蒙与硬件43」UI互动应用篇20 - 闪烁按钮效果
|
10天前
「Mac畅玩鸿蒙与硬件42」UI互动应用篇19 - 数字键盘应用
本篇将带你实现一个数字键盘应用,支持用户通过点击数字键输入数字并实时更新显示内容。我们将展示如何使用按钮组件和状态管理来实现一个简洁且实用的数字键盘。
52 17
「Mac畅玩鸿蒙与硬件42」UI互动应用篇19 - 数字键盘应用
|
17天前
|
UED 开发者
「Mac畅玩鸿蒙与硬件36」UI互动应用篇13 - 数字滚动抽奖器
本篇将带你实现一个简单的数字滚动抽奖器。用户点击按钮后,屏幕上的数字会以滚动动画的形式随机变动,最终显示一个抽奖数字。这个项目展示了如何结合定时器、状态管理和动画实现一个有趣的互动应用。
70 23
「Mac畅玩鸿蒙与硬件36」UI互动应用篇13 - 数字滚动抽奖器
|
13天前
|
前端开发 UED
「Mac畅玩鸿蒙与硬件39」UI互动应用篇16 - 倒计时环形进度条
本篇将带你实现一个倒计时环形进度条应用。用户可以设置倒计时的时间,启动倒计时后,应用会动态显示一个随着时间递减的环形进度条,同时伴有数字倒计时显示。这是结合动画效果和时间管理的实用示例。
97 10
「Mac畅玩鸿蒙与硬件39」UI互动应用篇16 - 倒计时环形进度条
|
18天前
「Mac畅玩鸿蒙与硬件35」UI互动应用篇12 - 简易日历
本篇将带你实现一个简易日历应用,显示当前月份的日期,并支持选择特定日期的功能。用户可以通过点击日期高亮选中,还可以切换上下月份,体验动态界面的交互效果。
47 12
「Mac畅玩鸿蒙与硬件35」UI互动应用篇12 - 简易日历