看看这个标题看起来很简单,但它很棘手。我正在开发一个wpf应用程序,我需要动态生成按钮,标签和文本框。在我的VoltageView XAml文件中,我创建了一个stackpanel。在我的VoltageChannelView xaml文件中,我创建了所有UI组件。
我在某种程度上取得了如下成就:
VoltageView:
<Grid Grid.Row="1" Style="{DynamicResource styleBackground}" Name="VoltageChannels" >
<StackPanel Height="Auto" Name="stackPanel" Width="Auto" MinHeight="300"></StackPanel>
</Grid>
VoltageChannelView:
<Label Grid.Column="0" Content="{Binding ChannelName}" />
<TextBox Grid.Column="1" Text="{Binding VoltageText}" />
<Button Grid.Column="1" Content="Set" CommandParameter="{Binding VoltageText}" Command="{Binding VoltageCommand}" />
我将以上动态生成的Ui组件添加到我的 VoltageView.xaml.cs 中的stackpanel,如下所示:
VoltageViewModel mVoltageViewModel = new VoltageViewModel();
// Called in constructor
public void OnChildAdd()
{
foreach (VoltageBoardChannel mVoltageChannelViewModel in mVoltageViewModel.VoltageChannelList)
{
VoltageChannelView mVoltageChannelView = new VoltageChannelView();
mVoltageChannelView.Margin = new Thickness(2);
mVoltageChannelView.ChannelInfo = mVoltageChannelViewModel;
stackPanel.Children.Add(mVoltageChannelView);
}
}
VoltageViewModel类:
public ObservableCollection<VoltageBoardChannel> channelList = null;
public ObservableCollection<VoltageBoardChannel> redhookChannels = new ObservableCollection<VoltageBoardChannel>
{
new VoltageBoardChannel { ChannelName = "VDD_IO_AUD", IsAvailable = true},
new VoltageBoardChannel { ChannelName = "VDD_CODEC_AUD", IsAvailable = true},
new VoltageBoardChannel { ChannelName = "VDD_DAL_AUD", IsAvailable = true},
new VoltageBoardChannel { ChannelName = "VDD_DPD_AUD", IsAvailable = true},
new VoltageBoardChannel { ChannelName = "VDD_PLL_AUD", IsAvailable = true},
new VoltageBoardChannel { ChannelName = "VDD_AMP1_AUD", IsAvailable = true}
};
public ObservableCollection<VoltageBoardChannel> bavaria1Channels = new ObservableCollection<VoltageBoardChannel>
{
new VoltageBoardChannel { ChannelName = "VDD__MAIN", IsAvailable = true},
new VoltageBoardChannel { ChannelName = "VDD__IO", IsAvailable = true},
new VoltageBoardChannel { ChannelName = "VDD__CODEC", IsAvailable = true},
new VoltageBoardChannel { ChannelName = "VDD__LDO", IsAvailable = true},
new VoltageBoardChannel { ChannelName = "VDD__AMP", IsAvailable = true},
};
public VoltageViewModel()
{
channelList = new ObservableCollection<VoltageBoardChannel>();
channelList = bavaria1Channels;
}
public ObservableCollection<VoltageBoardChannel> VoltageChannelList
{
get
{
return channelList;
}
set
{
channelList = value;
OnPropertyChanged("ChannelList");
}
}
RelayCommand _voltageCommand;
public ICommand VoltageCommand
{
get
{
if (_voltageCommand == null)
{
_voltageCommand = new RelayCommand(param => this.DoSomethingExecute, param => this.DoSomethingCanExecute);
}
return _voltageCommand;
}
}
public bool DoSomethingCanExecute(object param)
{
return true;
}
public void DoSomethingExecute(object param)
{
}
正如您在启动时看到的那样显示 BAVARIA1 频道。
VoltageBoardChannel(Model)Class:
private string mChannelName;
public string ChannelName
{
get
{
return mChannelName;
}
set
{
mChannelName = value;
OnPropertyChanged("ChannelName");
}
}
private bool mIsAvailable;
public bool IsAvailable
{
get; set;
}
string voltageText = string.Empty;
public string VoltageText
{
get
{
return voltageText;
}
set
{
voltageText = value;
OnPropertyChanged("VoltageText");
}
}
因此,当我运行应用程序时,它会在列表中维护4次动态显示bavaria1通道。现在,每个动态生成的控件都有一个文本框和按钮。
您可以注意到VoltageChannelView.xaml
我已经完成了绑定bw按钮和文本框。我想在文本框中输入值,在SET按钮上单击,它应该检索输入的值,以便可以进行进一步的操作。基本上应该有SET按钮的事件,它应该将文本框中写入的文本作为参数传递。
我怎样才能实现它? :)
答案 0 :(得分:1)
当我看到这个权利时,你错过了你的命令的实现。 你需要的是一个处理命令的逻辑。
从本文WPF Apps With The Model-View-ViewModel Design Pattern
复制来源RelayCommand Class
public class RelayCommand : ICommand
{
#region Fields
readonly Action<object> _execute;
readonly Predicate<object> _canExecute;
#endregion // Fields
#region Constructors
public RelayCommand(Action<object> execute)
: this(execute, null)
{
}
public RelayCommand(Action<object> execute, Predicate<object> canExecute)
{
if (execute == null)
throw new ArgumentNullException("execute");
_execute = execute;
_canExecute = canExecute;
}
#endregion // Constructors
#region ICommand Members
[DebuggerStepThrough]
public bool CanExecute(object parameter)
{
return _canExecute == null ? true : _canExecute(parameter);
}
public event EventHandler CanExecuteChanged
{
add { CommandManager.RequerySuggested += value; }
remove { CommandManager.RequerySuggested -= value; }
}
public void Execute(object parameter)
{
_execute(parameter);
}
#endregion // ICommand Members
}
你的Command的实现应该如下:
RelayCommand _voltageCommand ;
public ICommand VoltageCommand
{
get
{
if (_voltageCommand == null)
{
_voltageCommand = new RelayCommand(this.DoSomethingExecute,
this.DoSomethingCanExecute);
}
return _voltageCommand;
}
}
<强> Executemethod:强>
public void DoSomethingExecute(object param)
{
// param is your string
//Do Something with VoltageText
}
<强> CanExecutemethod 强>
public bool DoSomethingCanExecute(object param)
{
return true;
}