是的,设计失败并且没有选项定制。对于此类问题,我更喜欢Grid。您可以使用带有百分比的列或行。
默认位置。
<Shell.TitleView>
<Grid>
<ffimageloadingsvg:SvgCachedImage
Source="https://stackoverflow.design/assets/img/logos/so/logo-stackoverflow.svg"
Margin="10"/>
</Grid>
</Shell.TitleView>
data:image/s3,"s3://crabby-images/53e51/53e5107e1d7c82b4dffac63cc92032b105b68f4c" alt="默认视图"
在此示例中,第一列为 4/5 单位,第二列为 1/5 单位(* 符号表示百分比或除数)。
<Shell.TitleView>
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="4*"/>
<ColumnDefinition Width="1*"/>
</Grid.ColumnDefinitions>
<BoxView BackgroundColor="Yellow"/>
<BoxView Grid.Column="1" BackgroundColor="LightGoldenrodYellow"/>
</Grid>
</Shell.TitleView>
data:image/s3,"s3://crabby-images/1644d/1644d2d0a98db62d1cb6e9210e2607a2a162d062" alt="示例布局"
然后将图像文本或控件添加到首选布局(图像控件默认列是 0)。
<Shell.TitleView>
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="4*"/>
<ColumnDefinition Width="1*"/>
</Grid.ColumnDefinitions>
<ffimageloadingsvg:SvgCachedImage
Source="https://stackoverflow.design/assets/img/logos/so/logo-stackoverflow.svg"
Margin="10"/>
</Grid>
</Shell.TitleView>
data:image/s3,"s3://crabby-images/cebe9/cebe9c0adad8d2504321b301a457acca4d169644" alt="结果视图"
编辑:将最小高度添加到网格或图像控件以防止调整内容大小。ffimageloadingsvg也是用于加载 svg 文件的第三方包。