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

做电影网站会违法吗免费永久网站制作

做电影网站会违法吗,免费永久网站制作,网站建设技术服务合同,合肥装修本文列举了部分用于优化动画时延的正反案例#xff0c;帮助开发者在遇到相似场景时进行优化#xff0c;解决构建页面动画时遇到动画时延较长的问题。 减少动画丢帧 在播放动画或者生成动画时#xff0c;画面产生停滞而导致帧率过低的现象#xff0c;称为动画丢帧。 播放…本文列举了部分用于优化动画时延的正反案例帮助开发者在遇到相似场景时进行优化解决构建页面动画时遇到动画时延较长的问题。 减少动画丢帧 在播放动画或者生成动画时画面产生停滞而导致帧率过低的现象称为动画丢帧。 播放动画时系统需要在一个刷新周期内完成动画变化曲线的计算完成组件布局绘制等操作。建议使用系统提供的动画接口只需设置曲线类型、终点位置、时长等信息就能够满足常用的动画功能减少UI主线程的负载。 反例应用使用了自定义动画动画曲线计算过程很容易引起UI线程高负载易导致丢帧。 Entry Component struct AttrAnimationExample0 {State widthSize: number 200State heightSize: number 100State flag: boolean truecomputeSize() {let duration 2000let period 16let widthSizeEnd 0let heightSizeEnd 0if (this.flag) {widthSizeEnd 100heightSizeEnd 50} else {widthSizeEnd 200heightSizeEnd 100}let doTimes duration / periodlet deltaHeight (heightSizeEnd - this.heightSize) / doTimeslet deltaWeight (widthSizeEnd - this.widthSize) / doTimesfor (let i 1; i doTimes; i) {let t period * (i);setTimeout(() {this.heightSize this.heightSize deltaHeightthis.widthSize this.widthSize deltaWeight}, t)}this.flag !this.flag}build() {Column() {Button(click me).onClick(() {let delay 500setTimeout(() { this.computeSize() }, delay)}).width(this.widthSize).height(this.heightSize).backgroundColor(0x317aff)}.width(100%).margin({ top: 5 })} } 使用系统提供的属性动效API 建议通过系统提供的属性动效API实现上述动效功能。 Entry Component struct AttrAnimationExample1 {State widthSize: number 200State heightSize: number 100State flag: boolean truebuild() {Column() {Button(click me).onClick((event?: ClickEvent | undefined) {if (this.flag) {this.widthSize 100this.heightSize 50} else {this.widthSize 200this.heightSize 100}this.flag !this.flag}).width(this.widthSize).height(this.heightSize).backgroundColor(0x317aff).animation({duration: 2000, // 动画时长curve: Curve.Linear, // 动画曲线delay: 500, // 动画延迟iterations: 1, // 播放次数playMode: PlayMode.Normal // 动画模式}) // 对Button组件的宽高属性进行动画配置}.width(100%).margin({ top: 5 })} } 更详细的API文档请参考属性动画。 使用系统提供的显式动效API 建议通过系统提供的显式动效API实现上述动效功能。 Entry Component struct AnimateToExample2 {State widthSize: number 200;State heightSize: number 100;State flag: boolean true;build() {Column() {Button(click me).onClick((event?: ClickEvent | undefined) {if (this.flag) {animateTo({duration: 2000, // 动画时长curve: Curve.Linear, // 动画曲线delay: 500, // 动画延迟iterations: 1, // 播放次数playMode: PlayMode.Normal // 动画模式}, () {this.widthSize 100;this.heightSize 50;})} else {animateTo({duration: 2000, // 动画时长curve: Curve.Linear, // 动画曲线delay: 500, // 动画延迟iterations: 1, // 播放次数playMode: PlayMode.Normal // 动画模式}, () {this.widthSize 200;this.heightSize 100;})}this.flag !this.flag;}).width(this.widthSize).height(this.heightSize).backgroundColor(0x317aff)}.width(100%).margin({ top: 5 })} } 更详细的API文档请参考显式动画。 优化效果 相比于自定义动画使用系统提供的动效API可提高动画帧数提高应用性能。 动画实现方式帧数fps自定义动画60属性动效API120显式动效API120 合理设置隐式动画 Tabs组件在不为BottomTabBarStyle样式时切换页面时默认加载300ms的隐式动画如果开发场景不需要该动画效果会因默认加载导致页面跳转完成时延变长此时可手动设置animationDuration减少动画完成时延。下述正反示例分别为100ms和1000ms的动画时延 反例 Entry Component struct TabsExample {...private controller: TabsController new TabsController();build() {Column() {Tabs({ barPosition: BarPosition.Start, index: this.currentIndex, controller: this.controller }) {TabContent()TabContent()// ...}// ...// 设置Tabs页面跳转的动画时长为1000ms.animationDuration(1000)}.width(100%)} } 正例 Entry Component struct TabsExample {...private controller: TabsController new TabsController();build() {Column() {Tabs({ barPosition: BarPosition.Start, index: this.currentIndex, controller: this.controller }) {TabContent()TabContent()// ...}// ...// 设置Tabs页面跳转的动画时长为100ms.animationDuration(100)}.width(100%)} } 优化效果 优化前 1000ms优化后 100ms 上述示例通过减少animationDuration数值减少Tabs切换完成时延。当数值设置为0且TabBar不为BottomTabBarStyle样式时隐式动效延时为默认的300ms。开发者可根据实际场景适当减少隐式动效时延如果应用没有特殊的动效要求时建议设置数值为1减少阻塞主线程提高应用性能。 更详细的API文档请参考Tabs-animationduration。 合理设置动效时长 滚动类组件可使用fling方法按传入的初始速度进行惯性滚动不合理的滚动速度设置可能导致动效时长过长此时应通过加快滚动速度减少动效时长。下述正反示例通过改变List组件惯性滚动速度减少动效时长 反例 Entry Component struct ListExample {scrollerForList: Scroller new Scroller();build() {Column() {Button(Fling100).onClick(() {// 设置当前滚动初始速度为100vp/sthis.scrollerForList.fling(100);})List({ space: 20, initialIndex: 0, scroller: this.scrollerForList }) {// ...}}} } 正例 Entry Component struct ListExample {scrollerForList: Scroller new Scroller();build() {Column() {Button(Fling100).onClick(() {// 设置当前滚动初始速度为10000vp/sthis.scrollerForList.fling(10000);})List({ space: 20, initialIndex: 0, scroller: this.scrollerForList }) {// ...}}} } 优化效果 100vp/s 10000vp/s 示例动效耗时ms优化前392优化后200 上述示例在提高滚动速度到10000vp/s后相比100vp/s减少了200ms的动画时延。开发者可根据实际场景适当增加滚动速度在不影响页面效果的情况下减少页面完成时延提高应用性能。 最后 小编在之前的鸿蒙系统扫盲中有很多朋友给我留言不同的角度的问了一些问题我明显感觉到一点那就是许多人参与鸿蒙开发但是又不知道从哪里下手因为资料太多太杂教授的人也多无从选择。有很多小伙伴不知道学习哪些鸿蒙开发技术不知道需要重点掌握哪些鸿蒙应用开发知识点而且学习时频繁踩坑最终浪费大量时间。所以有一份实用的鸿蒙HarmonyOS NEXT文档用来跟着学习是非常有必要的。  为了确保高效学习建议规划清晰的学习路线涵盖以下关键阶段 GitCode - 全球开发者的开源社区,开源代码托管平台  希望这一份鸿蒙学习文档能够给大家带来帮助~ 鸿蒙HarmonyOS NEXT最新学习路线 ​ 该路线图包含基础技能、就业必备技能、多媒体技术、六大电商APP、进阶高级技能、实战就业级设备开发不仅补充了华为官网未涉及的解决方案 路线图适合人群 IT开发人员想要拓展职业边界零基础小白鸿蒙爱好者希望从0到1学习增加一项技能。技术提升/进阶跳槽发展瓶颈期提升职场竞争力快速掌握鸿蒙技术 2.视频学习教程学习PDF文档 HarmonyOS Next 最新全套视频教程 纯血版鸿蒙全套学习文档面试、文档、全套视频等        ​​ 总结 参与鸿蒙开发你要先认清适合你的方向如果是想从事鸿蒙应用开发方向的话可以参考本文的学习路径简单来说就是为了确保高效学习建议规划清晰的学习路线
http://www.yingshimen.cn/news/67250/

相关文章:

  • 企业网站建设实战教程网站开发是前端开发吗
  • 快速建立平台网站开发设计建站流程之梦网站怎么做seo
  • 自己开发网站怎么盈利国家和住房城乡建设部网站
  • 网站建设实训目的.tel域名不可以做网站域名吗
  • 网站的权重天津网站建设网络
  • 建设一个大型电影网站广州商砼建站规范
  • 苏州哪个公司做门户网站天猫设计师服务平台
  • 中堂镇仿做网站开发房地产需要多少钱
  • 新网站建设教程网站设计平台 动易
  • 中国空间站的意义阿里云企业邮箱怎么申请
  • 网站平台建设论文wordpress配置京东云
  • 网站建设管理ppt模板苏州做网站便宜的公司哪家好
  • 江门自助建站模板百度网站怎么做友情链接
  • 网站建设注意事项网站建设和app开发
  • 如何做推广麦当劳的网站网站批量创建程序
  • 海南网站网络推广邯郸58同城网
  • 高德地图怎么申报地址公司seo是什么级别
  • pcms网站开发响应式网站代码规范
  • 益阳房地产网站建设seo网站营销公司
  • 在哪个网站上做实验仪器比较好网站建设评估报告
  • 浙江省建设部网站揭阳网站免费建站
  • 如何对网站用户分析ppt设计兼职
  • 安徽省城乡建设网站wordpress评论表单获取qq
  • 旅游网站课程设计巩义网络推广公司
  • 做网站前端难吗万网官网登陆
  • 网站注销申请书国内比较高端的设计网站
  • 巴彦淖尔网站建设中国设计网作品欣赏
  • 快速搭建网站框架新手攻略龙岗建设网站
  • 上海营销网站推广多石家庄中企动力
  • 电视剧手机网站大全北湖建设局网站