复现步骤如下:
- 新建一个 FooScrollViewer 类型,让其继承 ScrollViewer 控件
- 在 FooScrollViewer 里面放入一个 Grid 和一个按钮,点击按钮时设置撑开 Grid 控件
具体代码如下,以下是 FooScrollViewer 类型的代码
public class FooScrollViewer : ScrollViewer
{
}
以下是 MainView.axaml 界面代码
<Grid x:Name="RootGrid" Background="Transparent"><views:FooScrollViewer><StackPanel x:Name="RootStackPanel" Margin="0 50 0 0"><Grid x:Name="TranslationPanel"><Border x:Name="FooBorder" Height="10" Background="#50565656"></Border><Button VerticalAlignment="Top" Content="点击" Click="Button_OnClick"></Button></Grid></StackPanel></views:FooScrollViewer></Grid>
点击按钮的时候的代码如下
private void Button_OnClick(object? sender, RoutedEventArgs e){FooBorder.Height += 200;}
尝试运行项目,然后不断点击按钮,可以看到 TranslationPanel 这个 Grid 高度已经到达一千六百多。但 RootStackPanel 依然是高度 600 多的值,且此时滚动条不出来
尝试将 views:FooScrollViewer
换成 ScrollViewer 控件,则 RootStackPanel 空间可以被撑开,且滚动条出现
本文代码放在 github 和 gitee 上,可以使用如下命令行拉取代码。我整个代码仓库比较庞大,使用以下命令行可以进行部分拉取,拉取速度比较快
先创建一个空文件夹,接着使用命令行 cd 命令进入此空文件夹,在命令行里面输入以下代码,即可获取到本文的代码
git init
git remote add origin https://gitee.com/lindexi/lindexi_gd.git
git pull origin 1479d0e9004e3f0648c9c5ead464227a963b6cb7
以上使用的是国内的 gitee 的源,如果 gitee 不能访问,请替换为 github 的源。请在命令行继续输入以下代码,将 gitee 源换成 github 源进行拉取代码。如果依然拉取不到代码,可以发邮件向我要代码
git remote remove origin
git remote add origin https://github.com/lindexi/lindexi_gd.git
git pull origin 1479d0e9004e3f0648c9c5ead464227a963b6cb7
获取代码之后,进入 AvaloniaIDemo/QeajewiyawarkogearLiqilela 文件夹,即可获取到源代码
更多技术博客,请参阅 博客导航