连接源图像中的绑定文本和静态文本

时间:2013-03-14 13:08:00

标签: c# binding windows-phone-8

是否可以将绑定文本与源图像中的静态文本连接起来 例如:

<Image Name="ImagePlace" Source="http://site.com/image/architecture.png"  Grid.Column="0" />
<Image Name="ImagePlace" Source="{Binding Path=Ico}"  Grid.Column="0" />

我想连接两个来源。

我有一个名为Category的对象列表,其中包含一个包含例如“architecture.png”的字段Icon。我把它绑在一个列表中。 网站的网址不会改变,但图像总是会改变。

<ListBox x:Name="ListboxCategories">
                <ListBox.ItemTemplate>
                    <DataTemplate>
                    <Button Name="category" Tag="{Binding Path=Id}" Tap="category_Tap_1">
                        <Grid>
                            <Grid.ColumnDefinitions>
                                <ColumnDefinition Width="*"/>
                                <ColumnDefinition Width="2*"/>
                                <ColumnDefinition Width="*"/>
                            </Grid.ColumnDefinitions>
                            <Image Name="ImagePlace" Source="http://www.test.com/assets/images/icons/tags/architecture.png"  Grid.Column="0" />
                            <TextBlock Text="{Binding Path=Title}" Grid.Column="1" HorizontalAlignment="Center" />
                            <Image Name="chevron" Grid.Column="2" Source="/Assets/AppBar/White/appbar.chevron.right.png" HorizontalAlignment="Right" Width="50" Height="50" />
                        </Grid>
                    </Button>
                    </DataTemplate>
                </ListBox.ItemTemplate>
            </ListBox>

1 个答案:

答案 0 :(得分:2)

最干净的方法(好吧,取决于你的架构)是在你的对象中添加一个属性来进行连接:

public string FullUri 
{ 
    get 
    { 
        return "http://site.com/image/" + this.Ico 
    } 
}

另一种方法是使用自定义转换器进行连接。

public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
{
    if (value == null)
    {
        return null;
    }

    return "http://site.com/image/" + value.ToString(); 
}