HarmonyOS 鸿蒙Next--通用标题栏

发布于 1周前 作者 htzhanglong 来自 鸿蒙OS

HarmonyOS 鸿蒙Next–通用标题栏
<markdown _ngcontent-kxw-c237="" class="markdownPreContainer">

hm_common_title_bar

介绍

一款通用标题栏,支持高度自定义,可设置沉浸式状态,正常状态下为:左侧返回、居中标题,左中右均可自定义视图。

软件架构

Harmony next版本,兼容API12

效果图

安装教程

  1. ohpm install common_title_bar

使用说明

  1. 引入仓库
  2. 设置全局属性:状态栏高度、是否全面屏、标题栏高度、标题栏颜色等(可忽略,使用默认配置)

基础使用:

import { CommonTitleBar, TitleType } from '[@ohos](/user/ohos)/commonTitleBar'
import { promptAction } from '@kit.ArkUI';

@Component export struct TitlePage { /**

  • rightType: TitleType.IMAGE时,设置了rightMorePopupData: this.rightMorePopup
  • 则会显示气泡菜单弹窗:如微信扫一扫弹窗 */ @State rightMorePopup: MenuItemOptions[] = [ { startIcon: $r(‘app.media.ic_edit’), content: “编辑资料”, }, { startIcon: $r(‘app.media.ic_download’), content: “上传信息”, }, { startIcon: $r(‘app.media.ic_upload’), content: “下载信息”, }, { startIcon: $r(‘app.media.ic_scan’), content: “扫一扫”, } ]

/**

  • 左侧自定义视图 */ @Builder leftBuilder() { Row() { Image($r(‘app.media.ic_arrow_left’)) .height(20) Text(‘返回’) .onClick(() => { promptAction.showToast({ message: “点击了左侧自定义视图”, duration: 1500, }) }) } }

/**

  • 右侧自定义视图 */ @Builder rightBuilder() { Row() { Text(‘更多’) .onClick(() => { promptAction.showToast({ message: “点击了右侧自定义视图”, duration: 1500, }) }) Image($r(‘app.media.ic_more’)) .height(20) } }

/**

  • 居中自定义视图 */ @Builder centerBuilder() { Row() { Image($r(‘app.media.ic_arrow_left’)) .height(20) Text(‘居中’) .onClick(() => { promptAction.showToast({ message: “点击了居中自定义视图”, duration: 1500, }) }) Image($r(‘app.media.ic_more’)) .height(20) } }

build() { NavDestination() { Scroll() { Column() { CommonTitleBar({ leftType: TitleType.NONE, centerType: TitleType.TEXT, centerText: “通用标题栏”, })

      CommonTitleBar({
        isFullScreen: <span class="hljs-keyword"><span class="hljs-keyword">false</span></span>,
        leftType: TitleType.TEXT,
        leftText: <span class="hljs-string"><span class="hljs-string">"返回"</span></span>,
        centerType: TitleType.TEXT,
        centerText: <span class="hljs-string"><span class="hljs-string">"非全面屏+左右文字"</span></span>,
        rightType: TitleType.TEXT,
        rightText: <span class="hljs-string"><span class="hljs-string">"更多"</span></span>,
      })

      <span class="hljs-javadoc"><span class="hljs-javadoc">/**
       * 左侧返回,右侧更多+气泡菜单
       */</span></span>
      CommonTitleBar({
        isFullScreen: <span class="hljs-keyword"><span class="hljs-keyword">false</span></span>,
        centerType: TitleType.TEXT,
        centerText: <span class="hljs-string"><span class="hljs-string">"左侧返回+右侧更多"</span></span>,
        rightType: TitleType.IMAGE,
        rightMorePopupData: <span class="hljs-keyword"><span class="hljs-keyword">this</span></span>.rightMorePopup,
        rightOnClick: (menu, index) =&gt; {
          promptAction.showToast({
            message: menu?.content + <span class="hljs-string"><span class="hljs-string">'---'</span></span> + index,
            duration: <span class="hljs-number"><span class="hljs-number">1500</span></span>,
          })
        }
      })

      CommonTitleBar({
        isFullScreen: <span class="hljs-keyword"><span class="hljs-keyword">false</span></span>,
        centerType: TitleType.TEXT,
        centerText: <span class="hljs-string"><span class="hljs-string">"自定义点击事件"</span></span>,
        centerOnClick: (): <span class="hljs-keyword"><span class="hljs-keyword">void</span></span> =&gt; {
          promptAction.showToast({
            message: <span class="hljs-string"><span class="hljs-string">"居中自定义事件"</span></span>,
            duration: <span class="hljs-number"><span class="hljs-number">1500</span></span>,
          })
        },
        leftOnClick: () =&gt; {
          promptAction.showToast({
            message: <span class="hljs-string"><span class="hljs-string">"左侧自定义事件"</span></span>,
            duration: <span class="hljs-number"><span class="hljs-number">1500</span></span>,
          })
        },
        rightType: TitleType.TEXT,
        rightText: <span class="hljs-string"><span class="hljs-string">"更多"</span></span>,
        rightOnClick: () =&gt; {
          promptAction.showToast({
            message: <span class="hljs-string"><span class="hljs-string">"右侧自定义事件"</span></span>,
            duration: <span class="hljs-number"><span class="hljs-number">1500</span></span>,
          })
        }
      })
      <span class="hljs-javadoc"><span class="hljs-javadoc">/**
       * 自定义视图
       */</span></span>
      CommonTitleBar({
        isFullScreen: <span class="hljs-keyword"><span class="hljs-keyword">false</span></span>,
        leftType: TitleType.CUSTOM,
        leftCustomView: <span class="hljs-keyword"><span class="hljs-keyword">this</span></span>.leftBuilder,
        centerType: TitleType.CUSTOM,
        centerCustomView: <span class="hljs-keyword"><span class="hljs-keyword">this</span></span>.centerBuilder,
        rightType: TitleType.CUSTOM,
        rightCustomView: <span class="hljs-keyword"><span class="hljs-keyword">this</span></span>.rightBuilder
      })

      <span class="hljs-javadoc"><span class="hljs-javadoc">/**
       * 跑马灯效果
       */</span></span>
      CommonTitleBar({
        isFullScreen: <span class="hljs-keyword"><span class="hljs-keyword">false</span></span>,
        leftWidth: <span class="hljs-number"><span class="hljs-number">80</span></span>,
        leftType: TitleType.TEXT,
        leftText: <span class="hljs-string"><span class="hljs-string">"超长文本时开启跑马灯效果"</span></span>,
        centerWidth: <span class="hljs-number"><span class="hljs-number">150</span></span>,
        centerText: <span class="hljs-string"><span class="hljs-string">"超长文本时开启跑马灯效果,超长文本时开启跑马灯效果,超长文本时开启跑马灯效果"</span></span>,
        rightWidth: <span class="hljs-number"><span class="hljs-number">80</span></span>,
        rightType: TitleType.TEXT,
        rightText: <span class="hljs-string"><span class="hljs-string">"超长文本时开启跑马灯效果"</span></span>,
        rightTextOverflow: TextOverflow.Ellipsis
      })

      <span class="hljs-javadoc"><span class="hljs-javadoc">/**
       * 中间搜索框
       */</span></span>
      CommonTitleBar({
        isFullScreen: <span class="hljs-keyword"><span class="hljs-keyword">false</span></span>,
        leftType: TitleType.NONE,
        centerType: TitleType.SEARCH,
        searchValue: <span class="hljs-string"><span class="hljs-string">"关键字"</span></span>,
        searchPlaceholder: <span class="hljs-string"><span class="hljs-string">"请输入产品名称"</span></span>,
        searchButtonText: <span class="hljs-string"><span class="hljs-string">"搜索"</span></span>,
        searchButtonOptions: {
          fontSize: <span class="hljs-number"><span class="hljs-number">14</span></span>,
          fontColor: Color.Red
        },
        onChangeSearch: (value) =&gt; {
          console.log(<span class="hljs-string"><span class="hljs-string">"Search:"</span></span> + value)
        },
        onSubmitSearch: (value) =&gt; {
          promptAction.showToast({
            message: value,
            duration: <span class="hljs-number"><span class="hljs-number">1500</span></span>,
          })
        }
      })

      <span class="hljs-javadoc"><span class="hljs-javadoc">/**
       * 中间搜索框 + 左侧返回 + 右侧更多
       */</span></span>
      CommonTitleBar({
        isFullScreen: <span class="hljs-keyword"><span class="hljs-keyword">false</span></span>,
        rightType: TitleType.IMAGE,
        rightMorePopupData: <span class="hljs-keyword"><span class="hljs-keyword">this</span></span>.rightMorePopup,
        rightOnClick: (menu, index) =&gt; {
          promptAction.showToast({
            message: menu?.content + <span class="hljs-string"><span class="hljs-string">'---'</span></span> + index,
            duration: <span class="hljs-number"><span class="hljs-number">1500</span></span>,
          })
        },
        centerLeftPadding: <span class="hljs-number"><span class="hljs-number">50</span></span>,
        centerRightPadding: <span class="hljs-number"><span class="hljs-number">50</span></span>,
        centerType: TitleType.SEARCH,
        searchPlaceholder: <span class="hljs-string"><span class="hljs-string">"请输入产品名称"</span></span>,
        searchButtonText: <span class="hljs-string"><span class="hljs-string">"搜索"</span></span>,
        searchButtonOptions: {
          fontSize: <span class="hljs-number"><span class="hljs-number">14</span></span>,
          fontColor: Color.Red
        },
        onChangeSearch: (value) =&gt; {
          console.log(<span class="hljs-string"><span class="hljs-string">"Search:"</span></span> + value)
        },
        onSubmitSearch: (value) =&gt; {
          promptAction.showToast({
            message: value,
            duration: <span class="hljs-number"><span class="hljs-number">1500</span></span>,
          })
        }
      })
      
      <span class="hljs-javadoc"><span class="hljs-javadoc">/**
       * 左侧返回方式:
       * BackType.
       * POP:使用NavPathStack.pop() 返回到上一页,默认方式
       * POP_TO_NAME:使用NavPathStack.popToName("name") 返回到上一个name页面
       * POP_TO_INDEX:使用NavPathStack.popToIndex(1) 返回到索引为1的页面
       * CLEAR:使用NavPathStack.clear() 返回到根首页(清除栈中所有页面)
       * ROUTER:使用router.back() 返回到上一页
       * 取决页面使用Router还是Navigation(推荐)导航
       */</span></span>
      CommonTitleBar({
        isFullScreen: <span class="hljs-keyword"><span class="hljs-keyword">false</span></span>,
        centerText: <span class="hljs-string"><span class="hljs-string">"左侧返回方式"</span></span>,
        leftBackType: BackType.ROUTER
      })

      <span class="hljs-javadoc"><span class="hljs-javadoc">/**
       * 基础属性设置
       */</span></span>
      CommonTitleBar({
        centerText: <span class="hljs-string"><span class="hljs-string">"基础属性设置"</span></span>,
        isFullScreen: <span class="hljs-keyword"><span class="hljs-keyword">true</span></span>,
        statusBarHeight: <span class="hljs-number"><span class="hljs-number">50</span></span>,
        statusBarColor: Color.Blue,
        titleBarHeight: <span class="hljs-number"><span class="hljs-number">56</span></span>,
        titleBarColor: Color.Green,
        showBottomLine: <span class="hljs-keyword"><span class="hljs-keyword">true</span></span>,
        bottomLineColor: Color.Red,
        bottomLineSize: <span class="hljs-number"><span class="hljs-number">5</span></span>,
      })

    }
  }
}
.hideTitleBar(<span class="hljs-keyword"><span class="hljs-keyword">true</span></span>)

} } <button style="position: absolute; padding: 4px 8px 0px; cursor: pointer; top: 4px; right: 8px; font-size: 14px;">复制</button>

视图类型:

export enum TitleType {
  NONE = 'none', // 空白
  TEXT = 'text', // 文字
  IMAGE = 'image', // 图标
  CUSTOM = 'custom', // 自定义
  SEARCH = 'search', // 居中搜索框
}
<button style="position: absolute; padding: 4px 8px 0px; cursor: pointer; top: 4px; right: 8px; font-size: 14px;">复制</button>

左侧返回方式:

/**
 * 返回方式
 * 使用POP、POP_TO_NAME、POP_TO_INDEX、CLEAR,需要在MainPage主页面设置:[@Provide](/user/Provide)('appPathStack') appPathStack: NavPathStack = new NavPathStack();
 * MainPage为其他使用CommonTitleBar子组件的主组件
 * 如果使用以下方式,自定义左侧图图标点击事件(onClickLeftImage)即可
 */
export enum BackType {
  NONE = 'none', // 无点击事件
  ROUTER = 'router', // router.back() 返回到上一页
  POP = 'pop', // NavPathStack.pop() 返回到上一页;默认方式
  POP_TO_NAME = 'popToName', // NavPathStack.popToName("name") 返回到上一个name页面
  POP_TO_INDEX = 'popToIndex', // NavPathStack.popToIndex(1) 返回到索引为1的页面
  CLEAR = 'clear', // NavPathStack.clear() 返回到根首页(清除栈中所有页面)
}
<button style="position: absolute; padding: 4px 8px 0px; cursor: pointer; top: 4px; right: 8px; font-size: 14px;">复制</button>

CommonTitleBar属性介绍:

属性 默认值 说明
主体设置
isFullScreen boolean:true 是否是全面沉浸是屏
statusBarHeight Length:36 状态栏高度(全面沉浸式屏生效)
titleBarHeight Length:56 标题栏高度
titleBarColor ResourceColor:'#f5f5f5' 标题栏颜色
statusBarColor ResourceColor:'#f5f5f5' 状态栏颜色 默认 等于标题栏颜色
showBottomLine boolean:true 是否显示标题栏底部的分割线
bottomLineSize Length:1 标题栏底部的分割线的宽度
bottomLineColor ResourceColor:"#DDDDDD" 标题栏分割线颜色
左侧设置
leftType string:TitleType.IMAGE 左侧视图类型,默认显示返回按钮
leftWidth Length:-1 左侧视图宽度,不设置则自适应内容
leftLeftPadding Length:15 左侧视图左内间距
leftRightPadding Length:5 左侧视图右内间距
leftText ResourceStr:'Left' 左侧文字leftType = text 有效
leftTextColor ResourceColor:"#000000" 左侧文字颜色
leftTextSize Length:16 左侧文字大小
leftTextOverflow TextOverflow:TextOverflow.MARQUEE 左侧文本,超长时的显示方式,默认跑马灯效果;
leftImageResource ResourceStr PixelMap:返回图标
leftImageWidth Length:26 左侧图标宽度
leftImageHeight Length:26 左侧图标高度
leftImagePadding Length:5 左侧图标padding值:图标尺寸16,内间距各5,保证点击范围
leftBackType string:BackType.POP 返回方法,不设置leftOnClick的情况下生效
leftPopToName string:'' BackType.POP_TO_NAME下生效:NavPathStack.popToName("name") 方式的页面名称
leftPopToIndex number:0 BackType.POP_TO_INDEX下生效:NavPathStack.popToIndex(1) 返回到索引为1的页面
leftCustomView [@Builder](/user/Builder): 左侧自定义视图
leftOnClick () => void 左侧点击事件
右侧设置
rightType string:TitleType.NONE 右侧视图类型,默认无视图
rightWidth Length:-1 右侧宽度,不设置则自适应内容
rightLeftPadding Length:5 右侧视图左内间距
rightRightPadding Length:15 右侧视图右内间距
rightText ResourceStr:'Right' 右侧文字leftType = text 有效
rightTextColor ResourceColor:"#000000" 右侧文字颜色
rightTextSize Length:16 右侧文字大小
rightTextOverflow TextOverflow:TextOverflow.MARQUEE 右侧文本,超长时的显示方式,默认跑马灯效果
rightImageResource ResourceStr PixelMap:更多图标
rightMorePopupView [@Builder](/user/Builder):更多-气泡菜单 如果默认使用更多图标,可默认展示气泡菜单
rightMorePopupData MenuItemOptions[]:[] 气泡菜单数据列表
rightImageWidth Length:26 右侧图标宽度
rightImageHeight Length:26 右侧图标高度
rightImagePadding Length:5 右侧图标padding值:图标尺寸16,内间距各5,保证点击范围
rightCustomView [@Builder](/user/Builder): 右侧自定义视图
rightOnClick (item?: MenuItemOptions, index?: number) => void 右侧点击事件
居中设置
centerType string:TitleType.TEXT 居中视图类型,默认文字视图
centerWidth Length:-1 居中宽度,不设置则自适应内容
centerText ResourceStr:'Center' 居中文字leftType= text 有效
centerTextColor ResourceColor:"#000000" 居中文字颜色
centerTextSize Length:16 居中文字大小
centerTextOverflow TextOverflow: TextOverflow.MARQUEE 居中文本,超长时的显示方式,默认跑马灯效果
centerOnClick () => void 居中文字点击事件
centerImageResource ResourceStr PixelMap:无
centerImageWidth Length:26 居中图标宽度
centerImageHeight Length:26 居中图标高度
centerImagePadding Length:5 居中图标padding值:图标尺寸16,内间距各5,保证点击范围
centerCustomView [@Builder](/user/Builder):无 居中自定义视图
searchValue string:'' centerType = TitleType.SEARCH生效:居中搜索框文本
searchPlaceholder ResourceStr:'请输入关键字' 居中搜索框提示文本
searchButtonText string:'搜索' 设置搜索框末尾搜索按钮文本
searchButtonOptions SearchButtonOptions:无 设置搜索框末尾搜索按钮文本样式
onSubmitSearch (value: string) => void 点击搜索图标、搜索按钮或者按下软键盘搜索按钮时触发该回调
onChangeSearch (value: string) => void 输入内容发生变化时,触发该回调
centerLeftPadding Length:30 居中视图左内间距
centerRightPadding Lenght:30 居中视图右间距

CommonTitleBar全局属性设置:统一设置,整个项目均可生效,一般位于EntryAbility.ets中设置:

/**
       * 设置通用标题栏的全局属性
       * 主体设置
       */
      AppStorage.setOrCreate<boolean>(TitleGlobalAttribute.IS_FULL_SCREEN, true); // 全局设置是否是全面屏
      AppStorage.setOrCreate<number>(TitleGlobalAttribute.STATUS_BAR_HEIGHT, px2vp(area.topRect.height)); // 全局设置状态栏高度
      AppStorage.setOrCreate<number>(TitleGlobalAttribute.TITLE_BAR_HEIGHT, 56); // 全局设置标题栏高度
      AppStorage.setOrCreate<ResourceColor>(TitleGlobalAttribute.TITLE_BAR_COLOR, "#f5f5f5"); // 全局设置标题栏颜色
      AppStorage.setOrCreate<ResourceColor>(TitleGlobalAttribute.STATUS_BAR_COLOR, "#f5f5f5"); // 全局设置状态栏颜色
      AppStorage.setOrCreate<boolean>(TitleGlobalAttribute.SHOW_BOTTOM_LINE, true); // 全局设置是否显示标题栏底部的分割线
      AppStorage.setOrCreate<Length>(TitleGlobalAttribute.BOTTOM_LINE_SIZE, 1); // 全局设置标题栏底部的分割线的宽度
      AppStorage.setOrCreate<ResourceColor>(TitleGlobalAttribute.BOTTOM_LINE_COLOR, "#DDDDDD"); // 全局设置标题栏分割线颜色
  <span class="hljs-javadoc"><span class="hljs-javadoc">/**
   * 左侧设置
   */</span></span>
  AppStorage.setOrCreate&lt;string&gt;(TitleGlobalAttribute.LEFT_TYPE, TitleType.IMAGE); <span class="hljs-comment"><span class="hljs-comment">// 全局设置左侧视图类型</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.LEFT_LEFT_PADDING, <span class="hljs-number"><span class="hljs-number">15</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置左侧视图左内间距</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.LEFT_RIGHT_PADDING, <span class="hljs-number"><span class="hljs-number">5</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置左侧视图右内间距</span></span>
  AppStorage.setOrCreate&lt;ResourceColor&gt;(TitleGlobalAttribute.LEFT_TEXT_COLOR, <span class="hljs-string"><span class="hljs-string">"#000000"</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置左侧文字颜色</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.LEFT_TEXT_SIZE, <span class="hljs-number"><span class="hljs-number">16</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置左侧文字大小</span></span>
  AppStorage.setOrCreate&lt;ResourceStr | PixelMap&gt;(TitleGlobalAttribute.LEFT_IMAGE_RESOURCE,
    $r(<span class="hljs-string"><span class="hljs-string">'app.media.ic_arrow_left'</span></span>)); <span class="hljs-comment"><span class="hljs-comment">// 全局设置左侧图标</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.LEFT_IMAGE_WIDTH, <span class="hljs-number"><span class="hljs-number">26</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置左侧图标宽度</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.LEFT_IMAGE_HEIGHT, <span class="hljs-number"><span class="hljs-number">26</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置左侧图标高度</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.LEFT_IMAGE_PADDING, <span class="hljs-number"><span class="hljs-number">5</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置左侧图标padding</span></span>

  <span class="hljs-javadoc"><span class="hljs-javadoc">/**
   * 右侧设置
   */</span></span>
  AppStorage.setOrCreate&lt;string&gt;(TitleGlobalAttribute.RIGHT_TYPE, TitleType.NONE); <span class="hljs-comment"><span class="hljs-comment">// 全局设置右侧视图类型</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.RIGHT_LEFT_PADDING, <span class="hljs-number"><span class="hljs-number">5</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置右侧视图左内间距</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.RIGHT_RIGHT_PADDING, <span class="hljs-number"><span class="hljs-number">15</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置右侧视图右内间距</span></span>
  AppStorage.setOrCreate&lt;ResourceColor&gt;(TitleGlobalAttribute.RIGHT_TEXT_COLOR, <span class="hljs-string"><span class="hljs-string">"#000000"</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置右侧文字颜色</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.RIGHT_TEXT_SIZE, <span class="hljs-number"><span class="hljs-number">16</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置右侧文字大小</span></span>
  AppStorage.setOrCreate&lt;ResourceStr | PixelMap&gt;(TitleGlobalAttribute.RIGHT_IMAGE_RESOURCE,
    $r(<span class="hljs-string"><span class="hljs-string">'app.media.ic_more'</span></span>)); <span class="hljs-comment"><span class="hljs-comment">// 全局设置左侧图标</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.RIGHT_IMAGE_WIDTH, <span class="hljs-number"><span class="hljs-number">26</span></span>); <span class="hljs-comment"><span class="hljs-comment">//  全局设置右侧图标宽度</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.RIGHT_IMAGE_HEIGHT, <span class="hljs-number"><span class="hljs-number">26</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置右侧图标高度</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.RIGHT_IMAGE_PADDING, <span class="hljs-number"><span class="hljs-number">5</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置右侧图标padding</span></span>

  <span class="hljs-javadoc"><span class="hljs-javadoc">/**
   * 居中设置
   */</span></span>
  AppStorage.setOrCreate&lt;string&gt;(TitleGlobalAttribute.CENTER_TYPE, TitleType.TEXT); <span class="hljs-comment"><span class="hljs-comment">// 全局设置居中视图类型</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.CENTER_LEFT_PADDING, <span class="hljs-number"><span class="hljs-number">30</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置居中视图左内间距</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.CENTER_RIGHT_PADDING, <span class="hljs-number"><span class="hljs-number">30</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置居中视图右内间距</span></span>
  AppStorage.setOrCreate&lt;ResourceColor&gt;(TitleGlobalAttribute.CENTER_TEXT_COLOR, <span class="hljs-string"><span class="hljs-string">"#000000"</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置居中文字颜色</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.CENTER_TEXT_SIZE, <span class="hljs-number"><span class="hljs-number">16</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置居中文字大小</span></span>
  AppStorage.setOrCreate&lt;ResourceStr | PixelMap&gt;(TitleGlobalAttribute.CENTER_IMAGE_RESOURCE,<span class="hljs-string"><span class="hljs-string">''</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置居中图标</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.CENTER_IMAGE_WIDTH, <span class="hljs-number"><span class="hljs-number">26</span></span>); <span class="hljs-comment"><span class="hljs-comment">//  全局设置居中图标宽度</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.CENTER_IMAGE_HEIGHT, <span class="hljs-number"><span class="hljs-number">26</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置居中图标高度</span></span>
  AppStorage.setOrCreate&lt;Length&gt;(TitleGlobalAttribute.CENTER_IMAGE_PADDING, <span class="hljs-number"><span class="hljs-number">5</span></span>); <span class="hljs-comment"><span class="hljs-comment">// 全局设置居中图标padding</span></span>

<button style="position: absolute; padding: 4px 8px 0px; cursor: pointer; top: 4px; right: 8px; font-size: 14px;">复制</button>

</markdown>


更多关于HarmonyOS 鸿蒙Next--通用标题栏的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

3 回复

navigation不是可以设置标题栏?

更多关于HarmonyOS 鸿蒙Next--通用标题栏的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


确实可以的,不过和我需求不太一样嘛

HarmonyOS 鸿蒙Next–通用标题栏

HarmonyOS 鸿蒙Next中的通用标题栏提供了高度自定义的功能,支持左侧返回、居中标题,以及左中右均可自定义视图的布局。开发者可以通过设置不同的属性和组件来灵活调整标题栏的样式,包括标题文本、颜色、图标以及是否显示底部分割线等。

标题栏的自定义主要通过设置其属性和使用自定义组件来实现。例如,可以设置左侧视图的类型(如图片、文字、按钮或自定义视图),并为其指定相应的点击事件处理函数。同样,右侧和居中的视图也可以进行类似的自定义设置。

此外,HarmonyOS 鸿蒙Next还支持沉浸式状态栏的设置,使得应用界面更加美观和统一。如果开发者想要完全控制标题栏的布局和样式,可以通过隐藏Navigation组件自带的标题栏,并在内容区自定义一个标题栏组件来实现。

需要注意的是,在进行标题栏自定义时,应确保应用的界面设计和用户体验符合HarmonyOS的设计规范和最佳实践。如果遇到问题,可以参考官方文档和开发者社区的相关资源,以获取更详细的指导和帮助。

如果问题依旧没法解决请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html。

回到顶部