当前位置: 首页 > news >正文

后台网站手机版视频怎么做新闻头条今日要闻国内新闻最新

后台网站手机版视频怎么做,新闻头条今日要闻国内新闻最新,越南做彩票网站是违法的吗,WordPress滑动验证码插件多HAP 介绍 本示例展示多HAP开发,简单介绍了多HAP的使用场景,应用包含了一个entry HAP和两个feature HAP,两个feature HAP分别提供了音频和视频播放组件,entry中使用了音频和视频播放组件。 三个模块需要安装三个hap包&#xff…

多HAP

介绍

本示例展示多HAP开发,简单介绍了多HAP的使用场景,应用包含了一个entry HAP和两个feature HAP,两个feature HAP分别提供了音频和视频播放组件,entry中使用了音频和视频播放组件。 三个模块需要安装三个hap包,最终会在设备上安装一个主entry的hap包。

本示例用到了应用上下文Context接口 @ohos.app.ability.common媒体服务接口@ohos.multimedia.media

效果预览

1

使用说明:

1.第一步:点击Build->Build Hap(s)/APP(s)->Build Hap(s),构建三个模块的hap包。

2.第二步:使用IDE安装多Hap包。

2

4.第四步:点击video,进入video播放页面,可点击播放按钮播放视频。

工程目录

├──audioFeature/src/main/ets/
│  ├──application
│  │  └──MyAbilityStage.ets
│  ├──audioAbility
│  │  └──AudioAbility.ets
│  ├──pages
│  │  └──index.ets                            // audio组件的实现页面
│  └──util
│     └──Logger.ts                            // 日志工具
├──audioFeature/src/main/module.json5         // audio模块配置hap类型:"type": "feature"
│
├──entry/src/main/ets/
│  ├──application
│  │  └──MyAbilityStage.ets
│  ├──mainability
│  │  └──MainAbility.ets
│  ├──pages
│  │  └──index.ets                            // entry主应用入口,内含首页组件以及发起hap跳转逻辑
│  └──util
│     └──Logger.ts                            // 日志工具
├──entry/src/main/module.json5                // entry模块配置hap类型:"type": "entry" 
│
├──videoFeature/src/main/ets/
│  ├──application
│  │  └──MyAbilityStage.ets
│  ├──videoability
│  │  └──VideoAbility.ets
│  ├──pages
│  │  └──index.ets                            // video组件的实现页面 
│  └──util
│     └──Logger.ts                            // 日志工具
└──videoFeature/src/main/module.json5         // video模块配置hap类型:"type": "feature"
相关概念

entry:应用的主模块,一个应用中,只有一个entry类型的HAP,一般实现应用的入口界面、入口图标、主特性功能等

feature:应用的特性模块,一个应用中可以包含一个或者多个feature类型的HAP,也可以不含

多HAP:一个应用工程中存在一个entry HAP和多个feature HAP

具体实现

  • 新创建两个Module作为将被跳转的hap,分别命名为videoFeature,audioFeature。源码参考[Index.ets]
/** Copyright (c) 2022-2023 Huawei Device Co., Ltd.* Licensed under the Apache License, Version 2.0 (the "License")* you may not use this file except in compliance with the License.* You may obtain a copy of the License at**     http://www.apache.org/licenses/LICENSE-2.0** Unless required by applicable law or agreed to in writing, software* distributed under the License is distributed on an "AS IS" BASIS,* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.* See the License for the specific language governing permissions and* limitations under the License.*/import { common } from '@kit.AbilityKit';
import Logger from '../util/Logger'
import { BusinessError } from '@kit.BasicServicesKit';const TAG: string = 'Index'
const AUDIO: string = 'audio'
const VIDEO: string = 'video'
const BUNDLE_NAME: string = 'com.samples.multihap'
const AUDIO_ABILITY_NAME: string = "AudioAbility"
const VIDEO_ABILITY_NAME: string = "VideoAbility"@Entry
@Component
struct Index {private context?: common.UIAbilityContextbuild() {Row() {Column() {Button(AUDIO).fontSize(50).fontWeight(FontWeight.Bold).onClick(() => {if(this.context){this.context.startAbility({bundleName: BUNDLE_NAME,abilityName: AUDIO_ABILITY_NAME}).then(() => {Logger.info(TAG, 'start audio ability success')}).catch((error: BusinessError) => {Logger.error(TAG, 'start audio ability failed, error: ' + JSON.stringify(error))})}}).id('btnAudio').margin({bottom: 20})Button(VIDEO).fontSize(50).fontWeight(FontWeight.Bold).onClick(() => {if(this.context){this.context.startAbility({bundleName: BUNDLE_NAME,abilityName: VIDEO_ABILITY_NAME}).then(() => {Logger.info(TAG, 'start video ability success')}).catch((error: BusinessError) => {Logger.error(TAG, 'start video ability failed, error: ' + JSON.stringify(error))})}}).id('btnVideo')}.width('100%')}.height('100%')}aboutToAppear() {this.context = getContext(this) as common.UIAbilityContext}
}
  • 配置每个hap的type:把entry文件夹下的module.json5中"type": “entry”,videoFeature和audioFeature文件夹下的module.json5中"type": “feature”;

    • 使用Want跳转到其他的Ability:在entry模块的index.ets中通过common.UIAbilityContext()配置Want,作为多hap间信息传递的载体,用于应用组件间的信息传递;

    • want的配置:通过指定bundleName和abilityName可以唯一确定一个Ability。

    • 新hap的跳转:在entry模块index.ets首页中,在按钮.onclick()事件内,通过Want配置显式拉起一个新的指定的Ability。

      • 例如:以配置videoFeature模块Want配置为例,在触发按钮事件中加入配置的Want:
      • btn.onClick(() => {this.context.startAbility({ bundleName: BUNDLE_NAME, abilityName: AUDIO_ABILITY_NAME }}
      • 其中bundleName为appscope文件夹下app.json5中"bundleName": “com.samples.multihap”。
      • abilityName为videoFeature模块src/main/module.json5中abilities:[“name”: “VideoAbility”],

以上就是本篇文章所带来的鸿蒙开发中一小部分技术讲解;想要学习完整的鸿蒙全栈技术。可以在结尾找我可全部拿到!
下面是鸿蒙的完整学习路线,展示如下:
1

除此之外,根据这个学习鸿蒙全栈学习路线,也附带一整套完整的学习【文档+视频】,内容包含如下

内容包含了:(ArkTS、ArkUI、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、鸿蒙南向开发、鸿蒙项目实战)等技术知识点。帮助大家在学习鸿蒙路上快速成长!

鸿蒙【北向应用开发+南向系统层开发】文档

鸿蒙【基础+实战项目】视频

鸿蒙面经

在这里插入图片描述

为了避免大家在学习过程中产生更多的时间成本,对比我把以上内容全部放在了↓↓↓想要的可以自拿喔!谢谢大家观看!

http://www.mmbaike.com/news/87818.html

相关文章:

  • 驻马店做网站哪家好百度关键词投放
  • wordpress管理网站互联网关键词优化
  • 纯静态网站索引怎么做广告推销网站
  • 最新新闻热点事件摘抄长沙正规竞价优化推荐
  • 南京营销型网站制作推广方式有哪几种
  • dede制作动态网站模板下载网站友情链接连接
  • 公司做网站多高清的网站制作
  • 微信网站建设热线卡点视频软件下载
  • 自助网站制作系统源码培训课程网站
  • 网站开发项目方案书网络营销企业培训
  • 免费微网站系统免费找精准客户软件
  • 做网站最主要是那个一类商标短视频营销的特点
  • 快速知彼网络网站建设百度百家自媒体平台注册
  • 北仑宁波有没有做网站百度网盘资源搜索引擎搜索
  • wordpress网站复制seo搜索引擎优化实战
  • 做网站为什么要服务器2023年10月疫情恢复
  • 动漫网页模板seo挖关键词
  • 佛教网站建设_精品推荐黄色大气极乐古寺网站源码自己可以创建网站吗
  • 网站服务器时间在哪里查询域名搜索引擎入口
  • 做企业网站怎么接活有哪些免费推广网站
  • 郑州网站的优化淘宝关键词怎么选取
  • 云南省网站建设百度百科官网首页
  • 做网站技术要求怎么写百度推广外包
  • 专做女鞋的网站新网站如何让百度收录
  • 做网站怎样用链接赚钱青岛百度竞价
  • 如何在网站插做视频苏州网站制作开发公司
  • 公司做网站自己可以做黑帽seo联系方式
  • 哪些网站的做的好看的网站推广优化是什么意思
  • 商丘做网站网络营销名词解释
  • 公司网站后台密码国内最新新闻大事