Xamarin表单 - 获取图像以填充包含网格列的宽度?

时间:2017-01-30 10:49:03

标签: c# xaml xamarin.forms

Xamarin Forms遇到问题,试图确保图像与其包含列的宽度匹配。 (想象一下带有图片和描述的简单产品清单。)

XAML代码是:

<?xml version="1.0" encoding="UTF-8"?>
<ContentPage xmlns="http://xamarin.com/schemas/2014/forms"
             xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
             x:Class="formsApp.MainPage">
  <ContentPage.Padding>
    <OnPlatform x:TypeArguments="Thickness"
                iOS="20, 40, 20, 20"
                Android="20, 20, 20, 20"
                WinPhone="20, 20, 20, 20" />
  </ContentPage.Padding>
  <ContentPage.Content>
    <ScrollView>
      <StackLayout VerticalOptions="FillAndExpand"
                   HorizontalOptions="FillAndExpand"
                   Orientation="Vertical"
                   Spacing="15" >
        <Grid x:Name="testGrid"  VerticalOptions="Center">
        </Grid>
      </StackLayout>
    </ScrollView>
  </ContentPage.Content>
</ContentPage>

C#代码背后是:

public MainPage()
    {
        InitializeComponent();

        testGrid.BackgroundColor = Color.Gray;
        testGrid.Padding = new Thickness(10D);
        testGrid.RowDefinitions = new RowDefinitionCollection();
        testGrid.ColumnDefinitions = new ColumnDefinitionCollection();

        testGrid.ColumnDefinitions.Add(new ColumnDefinition { Width = new GridLength(1, GridUnitType.Star) });
        testGrid.ColumnDefinitions.Add(new ColumnDefinition { Width = new GridLength(3, GridUnitType.Star) });

        for (int MyCount = 0; MyCount < 20; MyCount++)
        {
            testGrid.RowDefinitions.Add(new RowDefinition { Height = new GridLength(1, GridUnitType.Star) });
        }

        for (int i = 0; i < testGrid.RowDefinitions.Count(); i++)
        {
            StackLayout st = new StackLayout() { Orientation = StackOrientation.Horizontal, HorizontalOptions = LayoutOptions.Center, IsClippedToBounds = true };

            st.Children.Add(new Image
            {
                Source = ImageSource.FromUri(new Uri("https://lh3.googleusercontent.com/nYhPnY2I-e9rpqnid9u9aAODz4C04OycEGxqHG5vxFnA35OGmLMrrUmhM9eaHKJ7liB-=w300")),
                Aspect = Aspect.AspectFit,
                HorizontalOptions = LayoutOptions.EndAndExpand
            });

            testGrid.Children.Add(st, 0, i);

            testGrid.Children.Add(new Label
                {
                    Text = "Row" + i + " description.... fdsfsdf sdf sdfsd fsdf sdf sdf sdfsd fsd fsdf sdf sd fsd fsdf "
            }, 1, i);

        }

    }

我已经应用了各种选项,例如将图像包装在堆栈布局中(包含堆栈布局上的选项),还将AspectFit和EndAndExpand添加到图像中,但它永远不会100%正确。Resultant view from a 5" KitKat Android Emulator

有什么建议吗?

由于

1 个答案:

答案 0 :(得分:1)

我认为这里的问题是EndAndExpand水平选项。据我所知,如果内容不合适,...AndExpand 会扩展相应的观看次数。此外,您已将网格的列宽设置为*3*,这意味着第一列将占据网格宽度的四分之一,因此没有可扩展的空间。

此问题有多种可能的解决方案 - 具体取决于您希望结果的外观。您可以针对列

获取Auto*
<Grid.ColumnDefinitions>
    <ColumnDefinition Width="Auto" />
    <ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>

或者您可以使图像仅使用可用空间

st.Children.Add(new Image
{
    Source = "...",
    Aspect = Aspect.AspectFit,
    HorizontalOptions = LayoutOptions.Fill
});

这两个选项都可以解决您的问题。

,请注意,您甚至可以做得更好。您可以使用ListView而不是使用网格。使用ListView s,您可以为您的单元格使用数据绑定的强大功能。您不必使用所有构建视图的代码来混淆代码,但可以在整洁的XAML中声明所有内容。