首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Xamarin使用正方形图像形成CollectionView

Xamarin使用正方形图像形成CollectionView
EN

Stack Overflow用户
提问于 2019-06-20 23:56:26
回答 3查看 2.8K关注 0票数 1

我想用Xamarin表单将图像列表显示为具有多行(2行或4行)的网格。网格的每个单元格都必须是正方形。我正在使用垂直布局的CollectionView,所需的跨度和DataTemplate中固定的HeightRequest。我得到多列网格,但我不能使图像(单元)成为正方形。

代码语言:javascript
复制
<CollectionView ItemsSource="{Binding .}">
            <CollectionView.ItemsLayout>
                <GridItemsLayout Orientation="Vertical" Span="2" />
            </CollectionView.ItemsLayout>
            <CollectionView.ItemTemplate>
                <DataTemplate>
                    <Image
                        HeightRequest="100"
                        x:Name="imageCell"
                        Aspect="AspectFill"
                        Source="{Binding .}" />
                </DataTemplate>
            </CollectionView.ItemTemplate>
        </CollectionView>
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2019-06-22 19:00:28

多亏了另一个答案,我最终得到了自定义ContentView,将HeightRequest设置为Width,并在其中设置图像。

代码语言:javascript
复制
    public class SquareView : ContentView
    {
        protected override void OnSizeAllocated(double width, double height)
        {
            base.OnSizeAllocated(width, height);
            HeightRequest = Width;
        }
    }

和XAML

代码语言:javascript
复制
<CollectionView
                ItemsSource="{Binding .}">
                <CollectionView.ItemsLayout>
                    <GridItemsLayout
                        Orientation="Vertical"
                        Span="2" />
                </CollectionView.ItemsLayout>
                <CollectionView.ItemTemplate>
                    <DataTemplate>
                        <views:SquareView>
                            <Image
                                HeightRequest="20"
                                Aspect="AspectFill"
                                Source="{Binding .}" />
                        </views:SquareView>
                    </DataTemplate>
                </CollectionView.ItemTemplate>
            </CollectionView>
票数 4
EN

Stack Overflow用户

发布于 2019-06-21 00:43:29

我复制了一个小样本。

我添加的唯一一件事就是将图像包装在一个contentview中,应用一个填充(你可以忽略它)

代码语言:javascript
复制
 <CollectionView.ItemsLayout>
                <GridItemsLayout Orientation="Vertical" Span="2" />
            </CollectionView.ItemsLayout>
            <CollectionView.ItemTemplate>
                <DataTemplate>
                    <ContentView Padding="0">
                    <Image Source="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSzJUY4JZTX9oYsSl1jclFvdsoXhtA0AfxqKkYX2P81Qb3cyX9o"
                           HeightRequest="150"
                           Aspect="AspectFill"
                           />
                        </ContentView>
                </DataTemplate>
            </CollectionView.ItemTemplate>
        </CollectionView>

票数 0
EN

Stack Overflow用户

发布于 2019-06-21 16:32:43

在DataTemplate中,不要使用<Image></Image>作为根布局。相反,可以使用其中一个布局控件(StackLayout、AbsoluteLayout等)或者ContentView,然后将一些样式或任何您喜欢的样式应用到CollectionView的根布局中。

代码语言:javascript
复制
<DataTemplate>
   <StackLayout>
      <Image
         HeightRequest="100"
         x:Name="imageCell"
         Aspect="AspectFill"
         Source="{Binding .}" />
   </StackLayout>
</DataTemplate>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56689789

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档