热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

鸿蒙模仿boss直聘客户端更新教程

前言:各位同学大家好,之前写过一篇鸿蒙模仿boss直聘文章。那个时候我自己天真的以为鸿蒙里面没有类似安卓里面的fragment,所以就用布局显示隐藏来实现的虽然效果是

前言:

各位同学大家好 ,之前写过一篇鸿蒙模仿boss直聘文章。那个时候我自己天真的以为鸿蒙里面没有类似安卓里面的fragment,所以就用布局显示隐藏来实现的 虽然效果是实现了但是并不是很理想 ,因为所有的逻辑都是写在同一个Ability 视图里面,当逻辑复杂了我们就很难处理了,不过之前·我查文档发现鸿蒙提供了 Fraction 小部分这个控件给我们开发使用,所以就更新一下之前的模仿boss直聘的客户端项目
那么废话不多说,我们正式开始。

效果图

带顶部导航的

鸿蒙 模仿boss直聘客户端更新教程
QQ截图20210118222943.png

鸿蒙 模仿boss直聘客户端更新教程
QQ截图20210118223003.png

鸿蒙 模仿boss直聘客户端更新教程
QQ截图20210118223029.png

鸿蒙 模仿boss直聘客户端更新教程
QQ截图20210118223042.png

不带tabbar顶部导航的

鸿蒙 模仿boss直聘客户端更新教程
image.png

鸿蒙 模仿boss直聘客户端更新教程
image.png

鸿蒙 模仿boss直聘客户端更新教程
image.png

鸿蒙 模仿boss直聘客户端更新教程
image.png

具体实现

我们这次更新使用 Fraction
底部布局

底部布局效果

鸿蒙 模仿boss直聘客户端更新教程
image.png

底部布局简单说下是一个线性布局 DirectionalLayout 水平方向里面写了四个 DirectionalLayout 线性布局 然后每个线性布局里面嵌套一个inage图片空间和text文本控件来显示底部的tab 然后我们在 底部布局到上面添加了一个StackLayout 布局来装载我们的Fraction 控件

MainAbility 逻辑具体具体实现

  • 1 自己的Ability 继承 FractionAbility

public class MainAbility extends FractionAbility implements Component.ClickedListener { private Image job_pageimage; private Image company_page_image; private Image chat_page_image; private Image mine_page_image; private Text job_pagetext,company_page_text ,chat_page_text ,mine_page_text; private DirectionalLayout job_pagedl , company_page_dl, chat_page_dl,mine_page_dl; @Override public void onStart(Intent intent) { super.onStart(intent); super.setUIContent(ResourceTable.Layout_ability_main); addHomeFraction(); initview(); } }

  • 2控件初始化、

private void initview() { job_pageimage= (Image) findComponentById(ResourceTable.Id_job_page_image); company_page_image= (Image) findComponentById(ResourceTable.Id_company_page_image); chat_page_image= (Image) findComponentById(ResourceTable.Id_chat_page_image); mine_page_image= (Image) findComponentById(ResourceTable.Id_mine_page_image); job_pagetext= (Text) findComponentById(ResourceTable.Id_job_page_text); company_page_text= (Text) findComponentById(ResourceTable.Id_company_page_text); chat_page_text= (Text) findComponentById(ResourceTable.Id_chat_page_text); mine_page_text= (Text) findComponentById(ResourceTable.Id_mine_page_text); job_pagedl= (DirectionalLayout) findComponentById(ResourceTable.Id_job_page_dl); company_page_dl= (DirectionalLayout) findComponentById(ResourceTable.Id_company_page_dl); chat_page_dl= (DirectionalLayout) findComponentById(ResourceTable.Id_chat_page_dl); mine_page_dl= (DirectionalLayout) findComponentById(ResourceTable.Id_mine_page_dl); job_pagedl.setClickedListener(this); company_page_dl.setClickedListener(this); chat_page_dl.setClickedListener(this); mine_page_dl.setClickedListener(this); }

  • 3 点击事件

@Override public void onClick(Component component) { switch (component.getId()){ case ResourceTable.Id_job_page_dl: job_pageimage.setPixelMap(ResourceTable.Media_ic_main_tab_find_pre); company_page_image.setPixelMap(ResourceTable.Media_ic_main_tab_company_nor); chat_page_image.setPixelMap(ResourceTable.Media_ic_main_tab_contacts_nor); mine_page_image.setPixelMap(ResourceTable.Media_ic_main_tab_my_nor); job_pagetext.setTextColor(Color.GREEN); company_page_text.setTextColor(Color.GRAY); chat_page_text.setTextColor(Color.GRAY); mine_page_text.setTextColor(Color.GRAY); layoutShow(0); break; case ResourceTable.Id_company_page_dl: job_pageimage.setPixelMap(ResourceTable.Media_ic_main_tab_find_nor); company_page_image.setPixelMap(ResourceTable.Media_ic_main_tab_company_pre); chat_page_image.setPixelMap(ResourceTable.Media_ic_main_tab_contacts_nor); mine_page_image.setPixelMap(ResourceTable.Media_ic_main_tab_my_nor); job_pagetext.setTextColor(Color.GRAY); company_page_text.setTextColor(Color.GREEN); chat_page_text.setTextColor(Color.GRAY); mine_page_text.setTextColor(Color.GRAY); layoutShow(1); break; case ResourceTable.Id_chat_page_dl: job_pageimage.setPixelMap(ResourceTable.Media_ic_main_tab_find_nor); company_page_image.setPixelMap(ResourceTable.Media_ic_main_tab_company_nor); chat_page_image.setPixelMap(ResourceTable.Media_ic_main_tab_contacts_pre); mine_page_image.setPixelMap(ResourceTable.Media_ic_main_tab_my_nor); job_pagetext.setTextColor(Color.GRAY); company_page_text.setTextColor(Color.GRAY); chat_page_text.setTextColor(Color.GREEN); mine_page_text.setTextColor(Color.GRAY); layoutShow(2); break; case ResourceTable.Id_mine_page_dl: job_pageimage.setPixelMap(ResourceTable.Media_ic_main_tab_find_nor); company_page_image.setPixelMap(ResourceTable.Media_ic_main_tab_company_nor); chat_page_image.setPixelMap(ResourceTable.Media_ic_main_tab_contacts_nor); mine_page_image.setPixelMap(ResourceTable.Media_ic_main_tab_my_pre); job_pagetext.setTextColor(Color.GRAY); company_page_text.setTextColor(Color.GRAY); chat_page_text.setTextColor(Color.GRAY); mine_page_text.setTextColor(Color.GREEN); layoutShow(3); break; default: break; } }

  • 4多个Fraction切换逻辑

public void layoutShow(int code){ switch (code){ case 0: getFractionManager() .startFractionScheduler() .replace(ResourceTable.Id_mainstack, new JobFraction()) .submit(); break; case 1: getFractionManager() .startFractionScheduler() .replace(ResourceTable.Id_mainstack, new CompanyFraction()) .submit(); break; case 2: getFractionManager() .startFractionScheduler() .replace(ResourceTable.Id_mainstack, new MessageFraction()) .submit(); break; case 3: getFractionManager() .startFractionScheduler() .replace(ResourceTable.Id_mainstack, new MinepageFraction()) .submit(); break; default: break; } }

  • 5 默认添加的Fraction

private void addHomeFraction(){ getFractionManager() .startFractionScheduler() .add(ResourceTable.Id_mainstack, new JobFraction()) .submit(); }

整个MainAbility 逻辑就比较清晰了我们通过监听底部tab切换的点击事件回调方法我们调用FractionAbility 里面的 replace 和add方法来切换Fraction 和默认加载主页的Fraction 来实现了我们的上面的效果还做到了代码的解耦 我们具体的每个碎片页面的逻辑我们就可以在每个独立的Fraction 单独去实现即可。

具体的fraction的内部逻辑我们简单说一下

  • 公司模块

布局文件

java逻辑代码

package com.example.tablist.fraction; import com.example.tablist.ResourceTable; import com.example.tablist.bean.PositionInfo; import com.example.tablist.config.Api; import com.example.tablist.provider.PositionProvider; import com.google.gson.Gson; import ohos.aafwk.ability.fraction.Fraction; import ohos.aafwk.content.Intent; import ohos.agp.components.Component; import ohos.agp.components.ComponentContainer; import ohos.agp.components.LayoutScatter; import ohos.agp.components.ListContainer; import java.util.List; /*** * * 创建人:xuqing * 创建2021年2月28日17:24:03 * 类说明: 公司模块 * */ public class AttentionFraction extends Fraction { private PositionProvider positionProvider; private ListContainer listContainer; @Override protected Component onComponentAttached(LayoutScatter scatter, ComponentContainer container, Intent intent) { Component compOnent=scatter.parse(ResourceTable.Layout_fraction_attention,container,false); return component; } protected void onStart(Intent intent) { super.onStart(intent); listCOntainer= (ListContainer) getFractionAbility().findComponentById(ResourceTable.Id_jop_page_list); getPostition(); } public void getPostition(){ Gson gson=new Gson(); PositionInfo positiOnInfo=gson.fromJson(Api.getPositioninfo(),PositionInfo.class); List list=positionInfo.getData(); positiOnProvider=new PositionProvider(list, getFractionAbility()); listContainer.setItemProvider(positionProvider); } }

几个fraction其实比较·简单都是加载本地死数据显示在listContainer 控件上面,其他几个fraction因为逻辑都差不多我这边就不展开一个一个讲 有兴趣的同学可以下载完整代码去查阅 。

顶部的导航问题

之前那一版顶部导航我们也没有去掉 其实这个很容易我们只需要在config.json文件中添加如下代码即可

"metaData":{ "customizeData":[ { "name": "hwc-theme", "value": "androidhwext:style/Theme.Emui.Light.NoTitleBar", "extra": "" } ] }

鸿蒙 模仿boss直聘客户端更新教程
image.png

到此鸿蒙模仿boss直聘客户端就讲完了 其他页面的实现都差别不大大家可以去下载完整代码查阅 这次算是更新教程。之前教程因为个人知识疏漏说以给大家补上 以免给各位同学造成误导 实在不好意思

最后总结

鸿蒙里面提供的 Fraction(字面意思小部分)用法和安卓里面的fragment(碎片页)用法差不多 都是不能单独显示要依附于视图 。生命周期也比较类似 Fraction解决了我们常用app开发中多个tab切换的问题 ,所以这次使用 Fraction 控件 来更新了之前模仿 boss直聘项目,在这里我为之前的文章里面的描述错误给华为和各位同学道歉。当然 Fraction 也有缺陷 在实际开发中,我们可能需要让Fraction嵌套Fraction,目前鸿蒙还不支持Fraction嵌套Fraction。想信华为会尽快解决这个问题 我们也希望华为越来越好 王者归来 最后希望我的文章能帮助到各位解决问题 ,以后我还会贡献更多有用的代码分享给大家。各位同学如果觉得文章还不错 ,麻烦给关注和star,小弟在这里谢过啦!

项目地址

码云 :https://gitee.com/qiuyu123/newhms_boss


推荐阅读
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • Linux环境变量函数getenv、putenv、setenv和unsetenv详解
    本文详细解释了Linux中的环境变量函数getenv、putenv、setenv和unsetenv的用法和功能。通过使用这些函数,可以获取、设置和删除环境变量的值。同时给出了相应的函数原型、参数说明和返回值。通过示例代码演示了如何使用getenv函数获取环境变量的值,并打印出来。 ... [详细]
  • 标题: ... [详细]
  • IjustinheritedsomewebpageswhichusesMooTools.IneverusedMooTools.NowIneedtoaddsomef ... [详细]
  • 纠正网上的错误:自定义一个类叫java.lang.System/String的方法
    本文纠正了网上关于自定义一个类叫java.lang.System/String的错误答案,并详细解释了为什么这种方法是错误的。作者指出,虽然双亲委托机制确实可以阻止自定义的System类被加载,但通过自定义一个特殊的类加载器,可以绕过双亲委托机制,达到自定义System类的目的。作者呼吁读者对网上的内容持怀疑态度,并带着问题来阅读文章。 ... [详细]
  • 本文介绍了一款名为TimeSelector的Android日期时间选择器,采用了Material Design风格,可以在Android Studio中通过gradle添加依赖来使用,也可以在Eclipse中下载源码使用。文章详细介绍了TimeSelector的构造方法和参数说明,以及如何使用回调函数来处理选取时间后的操作。同时还提供了示例代码和可选的起始时间和结束时间设置。 ... [详细]
  • 本文详细介绍了Android中的坐标系以及与View相关的方法。首先介绍了Android坐标系和视图坐标系的概念,并通过图示进行了解释。接着提到了View的大小可以超过手机屏幕,并且只有在手机屏幕内才能看到。最后,作者表示将在后续文章中继续探讨与View相关的内容。 ... [详细]
author-avatar
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有