单击Button控件事件中未触发的图像

时间:2012-12-05 12:24:39

标签: c# wpf silverlight xaml

我有以下代码,单击图像时未触发Click事件。 当我在图像外部单击时,按钮单击事件将触发。

XAML:

<Grid x:Name="LayoutRoot" Background="White">
    <Button x:Name="btnMain" Background="Purple" >             
        <StackPanel x:Name="spButtonPanel" Background="Black">
            <telerik:RadImageEditor x:Name="imgButtonImage" />
            <TextBlock x:Name="tbButtonText" />
        </StackPanel>
    </Button>
</Grid>

CS:

this.btnMain.Click += new RoutedEventHandler(btnMain_Click);
this.imgButtonImage.MouseLeftButtonDown += new MouseButtonEventHandler(imgButtonImage_Click);
this.spButtonPanel.MouseLeftButtonDown += new MouseButtonEventHandler(spButtonPanel_Click);  

在x_Click事件中只是MessageBox.Show(“Button clicked”); 其中x是btn_Main等......

单击图像时,imgButtonImage_Click不会触发。 我也试过改变ZIndex无济于事。

4 个答案:

答案 0 :(得分:1)

为什么在按钮内的堆栈面板中使用<telerik:RadImageEditor x:Name="imgButtonImage" />?在按钮内部使用图像编辑器对我来说没有意义。 如果要在按钮内显示带有文本的图像,可以使用类似于:

的内容
<Button Style="{StaticResource MyButtonStyle}">  
    <StackPanel>  
        <Image Source="{Binding ...}  Margin="10" />  
        <TextBlock Text="Localizable Text" />  
    </StackPanel>  
</Button>

要使用base64string作为图像源,您可以执行以下操作:

string bgImage64 = //   image stored in string
byte[] binaryData = Convert.FromBase64String(bgImage64);

BitmapImage bi = new BitmapImage();
bi.BeginInit();
bi.StreamSource = new MemoryStream(binaryData);
bi.EndInit();

imgButtonImage.Source = bi;

要封装此代码并直接在xaml中使用,您可以创建IValueConverter并使用<Image Source="{Binding ...stringDataSource..., Converter={StaticResource MyBase64ImageConverter}}"/>

之类的内容

答案 1 :(得分:1)

使用JSimoes帮助解决它。

        BitmapImage bi = new BitmapImage();
        bi.SetSource(new MemoryStream(imageBytes));
        imgButtonImage.Source = bi;

感谢。

答案 2 :(得分:0)

我不知道Telerik RadImageEditor控件,但我猜它会处理鼠标冒泡事件。您应该使用隧道事件(事件名称以Preview开头),例如PreviewMouseLeftButtonDown

答案 3 :(得分:0)

尝试将事件添加到xaml

<Button x:Name="btnMain" Background="Purple" Click="btnMain_Click" >