如何制作可滚动的垂直网格图像

时间:2017-04-03 07:09:41

标签: c# windows-phone-8.1

我需要制作可沿垂直轴滚动的图像列表。

图片'链接位于string[] imagesLocation

单击tile时,事件处理程序应该知道string imageLocation

看起来应该是这样的:

enter image description here

我能够在网格中制作它。但是它无法滚动。

找到一些使用LongListSelector的提示,但无法使其发挥作用。

更新

MainPage.xaml.cs中:

namespace PhoneApp1
{
    public partial class MainPage : PhoneApplicationPage
    {
        public MainPage()
        {
            InitializeComponent();
            ContentPanel.ColumnDefinitions.Add(new ColumnDefinition() { Width = GridLength.Auto });
            ContentPanel.ColumnDefinitions.Add(new ColumnDefinition() { Width = new GridLength() });
            ContentPanel.RowDefinitions.Add(new RowDefinition() { Height = new GridLength() });
            ContentPanel.Children.Add(new TextBlock() { });
            for (int i = 0; i < 3; i++)
            {
                for (int j = 0; j < 5; j++)
                {
                    Image MyImage1 = new Image();
                    MyImage1.SetValue(Grid.ColumnProperty, i);
                    MyImage1.SetValue(Grid.RowProperty, j);

                    ImageSource src = new BitmapImage(new Uri(string.Format("Assets/ApplicationIcon.png"), UriKind.RelativeOrAbsolute));

                    MyImage1.Source = src;

                    ContentPanel.Children.Add(MyImage1);
                }
            }
        }
    }
}

MailPage.xaml:

<phone:PhoneApplicationPage
    x:Class="PhoneApp1.MainPage"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:phone="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone"
    xmlns:shell="clr-namespace:Microsoft.Phone.Shell;assembly=Microsoft.Phone"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d"
    FontFamily="{StaticResource PhoneFontFamilyNormal}"
    FontSize="{StaticResource PhoneFontSizeNormal}"
    Foreground="{StaticResource PhoneForegroundBrush}"
    SupportedOrientations="Portrait" Orientation="Portrait"
    shell:SystemTray.IsVisible="True">
    <Grid x:Name="LayoutRoot" Background="Transparent">
        <Grid.RowDefinitions>
            <RowDefinition Height="Auto"/>
            <RowDefinition Height="*"/>
        </Grid.RowDefinitions>
        <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28">
            <TextBlock Text="MY APPLICATION" Style="{StaticResource PhoneTextNormalStyle}" Margin="12,0"/>
            <TextBlock Text="page name" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/>
        </StackPanel>
        <Grid Grid.Row="1" x:Name="ContentPanel">
            <Grid.RowDefinitions>
                <RowDefinition Height="Auto"/>
                <RowDefinition Height="*"/>
            </Grid.RowDefinitions>
            <Grid.ColumnDefinitions>
                <ColumnDefinition Width="160"></ColumnDefinition>
                <ColumnDefinition Width="160"></ColumnDefinition>
                <ColumnDefinition Width="160"></ColumnDefinition>
            </Grid.ColumnDefinitions>

        </Grid>
    </Grid>

</phone:PhoneApplicationPage>

1 个答案:

答案 0 :(得分:0)

我想到了一个可以尝试的简单解决方案。 首先插入Panel,然后在panel

中创建网格

panel有一个名为AutoScroll的属性您只需将其设置为True

    panel.AutoScroll = "True";

WrapPanel非常适合以垂直或水平方向布置物品,直到您到达容器的边缘,然后移动到下一列或行。但遗憾的是,我发现Windows应用商店应用(通用应用)不再支持WrapPanel

UniversalWrapPanelWrapPanel布局的替代方案。

这是考虑您正在处理Visual Studio

要获取UniversalWrapPanel,请转到包管理器,查找并安装包UniversalWrapPanel这将在您的引用中添加DLL。

然后打开MainPage.xaml并将命名空间添加到XAML:

xmlns:UniversalWrapPanel="using:Gregstoll"