Avalonia跨平台入门第十四篇之ListBox折叠列表

在前面分享的几篇中咱已经玩耍了PopupListBox多选Grid动态分RadioButton模板控件的拖放效果控件的置顶和置底控件的锁定自定义Window样式动画效果Expander控件;今天趁着空闲时间接着去摸索基于ListBox的折叠列表的效果,最终实现的效果如下图:

d4684263a54b2f48711dce1cf204a934.gif

先来看看布局吧:

dd95a6b03a1053c662b77e75b01de15d.png

前台的布局代码:

3e1f83107391d209108c1819ec4a9b12.png

外面ListBox的子项模板:

<ListBox.ItemTemplate>
    <DataTemplate>
        <!--这里绑定ListBoxItem的IsSelected可以控制只展开一项-->
        <!--去掉绑定的话,可以展开多项-->
        <!--IsExpanded="{Binding $parent[ListBoxItem].IsSelected}"-->
        <Expander Header="{Binding Name}" Cores:AttachedDependencyHelper.ExpanderHeaderImg="{Binding HeaderImg}" 
                Foreground="White" Width="{Binding $parent[ListBox].Width}"
                HorizontalContentAlignment="Stretch" VerticalContentAlignment="Stretch">
            <ListBox Items="{Binding ChildData}" Width="260"
                 ItemTemplate="{StaticResource LisBoxItemTemplate}">
                <ListBox.Styles>
                    <Style Selector="ListBoxItem /template/ Border#OutBorder">
                        <Setter Property="Background" Value="#1C3466"/>
                     </Style>
                    <!--鼠标pointerover的颜色-->
                    <Style Selector="ListBoxItem:pointerover /template/ Border#OutBorder">
                        <Setter Property="Background" Value="#cc075c9f"/>
                     </Style>
                    <!--鼠标selected的颜色-->
                    <Style Selector="ListBoxItem:selected /template/ Border#OutBorder">
                        <Setter Property="Background" Value="#075C9F"/>
                     </Style>
                </ListBox.Styles>
            </ListBox>
        </Expander>
    </DataTemplate>
</ListBox.ItemTemplate>

里面的ListBox的子项模板:

<DataTemplate x:Key="LisBoxItemTemplate">
    <Grid Width="{Binding $parent[ListBox].Width}">
        <WrapPanel Orientation="Horizontal" Margin="30,0,0,0" VerticalAlignment="Center">
            <Image Source="{Binding ManagerType,Converter={StaticResource ManagerTypeEnumToImageConverter}}" Height="20" Stretch="Uniform"/>
            <TextBlock Margin="10,0,0,0" HorizontalAlignment="Center" Text="{Binding Path=Name,StringFormat={}我是{0}}" Foreground="White"/>
        </WrapPanel>
        <Button Classes="RemoveItemButton" Tag="{Binding}" IsVisible="{Binding $parent[ListBoxItem].IsSelected}" CommandParameter="{Binding .}"
        Command="{Binding DataContext.RemoveItemCommand,RelativeSource={RelativeSource AncestorType={x:Type ListBox} AncestorLevel=2}}"/>
    </Grid>
</DataTemplate>

最终简单的效果先这样吧31da6609389d87e753e0e4700435269e.png;回头可以基于玩耍一下联系人的效果;以后有时间的话,可以再去摸索一下更复杂的效果aeeaef49107245173accbce05957f7bf.png;编程不息、Bug不止、无Bug、无生活d5ffb13704e76abef5745ba0034071f1.png;改bug的冷静、编码的激情、完成后的喜悦、挖坑的激动 、填坑的兴奋;这也许就是屌丝程序员的乐趣吧;今天就到这里吧;希望自己有动力一步一步坚持下去;生命不息,代码不止;大家抽空可以看看今天分享的效果,有好的意见和想法,可以在留言板随意留言;我看到后会第一时间回复大家,多谢大家的一直默默的关注和支持!如果觉得不错,那就伸出您的小手点个赞并关注一下,多谢您的支持!

这个问题通常是由于Emgu.CV库在加载C++库时发生的错误导致的。为了解决这个问题,你可以尝试以下步骤: 1.确保你已经按照Emgu.CV的安装指南进行了安装,并且已经添加了所需的引用。 2.在你的项目中添加以下NativeLibrary.SetDllImportResolver代码,该代码会解决安卓项目下无法找到C++库的问题。 ```csharp using System.Runtime.InteropServices; using Emgu.CV; using NativeLibrary = System.Runtime.InteropServices.NativeLibrary; public static class Bootstrapper { public static void Init() { NativeLibrary.SetDllImportResolver(typeof(CvInvoke).Assembly, DllImportResolver); } private static IntPtr DllImportResolver(string libraryName, Assembly assembly, DllImportSearchPath? searchPath) { if (libraryName == "libgdiplus") { return LoadLibgdiplus(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "libgdiplus.so")); } return IntPtr.Zero; } [DllImport("libdl.so")] private static extern IntPtr dlopen(string filename, int flags); [DllImport("libdl.so")] private static extern IntPtr dlerror(); private static IntPtr LoadLibgdiplus(string path) { IntPtr lib = dlopen(path, RTLD_NOW); if (lib == IntPtr.Zero) { var error = Marshal.PtrToStringAnsi(dlerror()); throw new Exception($"Failed to load libgdiplus from '{path}'. {error}"); } return lib; } private const int RTLD_NOW = 2; } ``` 3.在你的Android项目的MainActivity.cs文件中添加以下代码,用于在应用程序启动时初始化Emgu.CV。 ```csharp protected override void OnCreate(Bundle savedInstanceState) { base.OnCreate(savedInstanceState); Bootstrapper.Init(); // Initialize Emgu.CV // Other initialization code } ``` 通过这些步骤,你应该可以解决System.TypeInitializationException: The type initializer for 'Emgu.CV.CvInvoke' threw an exception问题。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值