2016-11-02 167 views
0

我有這樣的代碼:訪問控制8.1

<HubSection x:Name="MyHub"> 
    <DataTemplate> 
     <Grid> 
      <Grid.RowDefinitions> 
       <RowDefinition Height="*"></RowDefinition> 
       <RowDefinition Height="200"></RowDefinition> 
      </Grid.RowDefinitions> 
      <Image x:Name="MYImage" Source="{Binding image}" Height="50" Width="60" VerticalAlignment="Center"/> 
      <StackPanel Orientation="Vertical"> 
       <TextBlock TextWrapping="Wrap" Width="200" VerticalAlignment="Center" HorizontalAlignment="Left" Text="{Binding name}"/> 
       <Button Content="Click me"> 
      </StackPanel> 
     </Grid> 
    </DataTemplate> 
</HubSection> 

但我不知道如何訪問文本塊,我想改變文本塊的前景色在後面的代碼。

+0

您可以添加datatriggers到您的文本塊,所以你可以根據屬性觸發顏色變化在你的模型上。 –

回答

0

XAML:

<Hub x:Name="myHub"> 
     <HubSection x:Name="myHubSection"> 
      <DataTemplate> 
       <TextBlock x:Name="textbox1" Text="text" Width="300" Height="100"> 
       </TextBlock> 
      </DataTemplate> 
     </HubSection> 
    </Hub> 

後面的代碼:

private void Page_Loaded(object sender, RoutedEventArgs e) 
    { 
     var hub_section = FindVisualChildByName<HubSection>(this.myHub, "myHubSection"); 
     var text_box = FindVisualChildByName<WebView>(hub_section, "textbox1"); 
    } 

    public static T FindVisualChildByName<T>(DependencyObject parent, string name)where T : DependencyObject 

    { 
     for (int i = 0; i < VisualTreeHelper.GetChildrenCount(parent); i++) 
     { 
      var child = VisualTreeHelper.GetChild(parent, i); 
      string controlName = child.GetValue(Control.NameProperty) as string; 
      if (controlName == name) 
      { 
       return child as T; 
      } 
      else 
      { 
       T result = FindVisualChildByName<T>(child, name); 
       if (result != null) 
        return result; 
      } 
     } 
     return null; 
    } 

更詳細的信息,您可以參考How to access a Control inside the data template in C# Metro UI in the code behind