HarmonyOS 鸿蒙Next--通用标题栏
HarmonyOS 鸿蒙Next–通用标题栏
<markdown _ngcontent-kxw-c237="" class="markdownPreContainer">
hm_common_title_bar
介绍
一款通用标题栏,支持高度自定义,可设置沉浸式状态,正常状态下为:左侧返回、居中标题,左中右均可自定义视图。
软件架构
Harmony next版本,兼容API12
效果图
安装教程
- ohpm install common_title_bar
使用说明
- 引入仓库
- 设置全局属性:状态栏高度、是否全面屏、标题栏高度、标题栏颜色等(可忽略,使用默认配置)
基础使用:
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) => {
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> => {
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: () => {
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: () => {
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) => {
console.log(<span class="hljs-string"><span class="hljs-string">"Search:"</span></span> + value)
},
onSubmitSearch: (value) => {
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) => {
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) => {
console.log(<span class="hljs-string"><span class="hljs-string">"Search:"</span></span> + value)
},
onSubmitSearch: (value) => {
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<string>(TitleGlobalAttribute.LEFT_TYPE, TitleType.IMAGE); <span class="hljs-comment"><span class="hljs-comment">// 全局设置左侧视图类型</span></span>
AppStorage.setOrCreate<Length>(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<Length>(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<ResourceColor>(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<Length>(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<ResourceStr | PixelMap>(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<Length>(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<Length>(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<Length>(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<string>(TitleGlobalAttribute.RIGHT_TYPE, TitleType.NONE); <span class="hljs-comment"><span class="hljs-comment">// 全局设置右侧视图类型</span></span>
AppStorage.setOrCreate<Length>(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<Length>(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<ResourceColor>(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<Length>(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<ResourceStr | PixelMap>(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<Length>(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<Length>(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<Length>(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<string>(TitleGlobalAttribute.CENTER_TYPE, TitleType.TEXT); <span class="hljs-comment"><span class="hljs-comment">// 全局设置居中视图类型</span></span>
AppStorage.setOrCreate<Length>(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<Length>(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<ResourceColor>(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<Length>(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<ResourceStr | PixelMap>(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<Length>(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<Length>(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<Length>(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
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。