Many WPF developers face a common problem when working with RadioButtons . They try to bind RadioButtons with a Gender property, but the binding does not work as expected . Why does this happen? Because RadioButtons work with true/false values , but in real applications, Gender is stored as meaningful values like: Male Female So the big question is: How do we connect a true/false UI control with a Male/Female data value? Why RadioButton Binding Fails A RadioButton uses the IsChecked property, and this property accepts only: true false But your Gender property is usually: a string ( "Male" , "Female" ) or an enum So the UI value and the data value are different types . This mismatch is the root cause of the problem. The Solution: Value Converter WPF provides a powerful feature called a Value Converter . What is a Value Converter? A Value Converter converts one value type into another. In our case: Convert Gender (...
Get link
Facebook
X
Pinterest
Email
Other Apps
How to apply theme and color in wpf Metro window application
Get link
Facebook
X
Pinterest
Email
Other Apps
In this example i am using Prism,unity and MahApps make sure you are also using same otherwise you will not get PrismApplication,BindableBase and MetroWindow.
</metro:MetroWindow.RightWindowCommands>
<StackPanel Orientation="Vertical" HorizontalAlignment="Center" VerticalAlignment="Center">
<!--here i used DynamicResource for Foreground/Background because i want to dynamically change the color-->
<TextBlock Height="30" Width="200" Text="This is TextBlock" Margin="5" Foreground="{DynamicResource AccentBaseColorBrush}"/>
<Button Content="This is Button" HorizontalAlignment="Left" Width="200" Background="{DynamicResource AccentBaseColorBrush}"/>
</StackPanel>
</metro:MetroWindow>
MainWindow.xaml.cs
public partial class MainWindow : MetroWindow
{
public MainWindow()
{
InitializeComponent();
DataContext = new MainWindowViewModel();
}
}
MainWindowViewModel.cs
public class MainWindowViewModel : BindableBase
{
public MainWindowViewModel()
{
ApplyThemeCommand = new DelegateCommand(ApplyTheme);
ApplyColorCommand = new DelegateCommand(ApplyColor);
_lstTheme = new ObservableCollection<NameValue>()
{
new NameValue() {Name = "Light", Value = "White"},
new NameValue() {Name = "Dark", Value = "Black"}
};
SelectedTheme = LstTheme[0];
_lstColor = new ObservableCollection<NameValue>()
{
new NameValue() {Name = "blue", Value = "#2196F3"},
new NameValue() {Name = "red", Value = "#e52400"},
new NameValue() {Name = "green", Value = "#60a917"},
new NameValue() {Name = "purple", Value = "#800080"},
new NameValue() {Name = "orange", Value = "#fa6800"}
<!-- MahApps.Metro resource dictionaries. Make sure that all file names are Case Sensitive! -->
<ResourceDictionary Source="pack://application:,,,/MahApps.Metro;component/Styles/Controls.xaml"/>
In this Post i will explain the pagination using the MVVM pattern. Lets first create the View with DataGrid and pagination control with First, Previous, Next and Last buttons and we will also have the number of record per page to be displayed in DataGrid option which is ComboBox and in this DataGrid i will load data from CSV file. View I will create the view with DataGrid like this And in this DataGrid i will load data from CSV file <Window x:Class="CURD.Views.EmployeeDetails" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:local="clr-namespace:CURD.Views" mc:Ignorable="d" Title="E...
Comments
Post a Comment