I have a user control that i am using inside a DataTemplate
, this UserControl
contains a TextBox
which is binded with Value p
Anurag,
There are a lot of assumptions I have to make here, but I'll give it a shot.
You probably have something like this...
// ...
public static string GetValue(Dependency obj)
{
// ...
}
// ...
public static void SetValue(DependencyObject obj, string value)
{
// ...
}
// Using a DependencyProperty as the backing store for Value. This enables animation, styling, binding, etc...
public static readonly DependencyProperty ValueProperty =
DependencyProperty.RegisterAttached("Value", typeof(string), typeof(MyCustomControl), new UIPropertyMetadata(OnValuePropertyChanged));
public static void OnValuePropertyChanged(DependencyObject obj, DependencyPropertyChangedEventArgs e)
{
string newValue = e.NewValue as string;
// You validate your value here,
// Then if fails, revert to old value.
if(!SomeCondtion(newValue)) SetValue(obj,e.OldValue as string);
}
This is definitely not the best approach to validate data. There are other, more efficient approaches that will give you more flexibility.
Don't use DependecyPropertyChanged callback method. Use a registered string Property and in your setter, apply logic, e.g.
public static readonly DependencyProperty ValueProperty = DependencyProperty.Register("Value", typeof(string), typeof(UserControlWithTextBox));
private string _oldValue;
public string Value
{
get { return GetValue(ValueProperty) as string; }
set
{
// Check if the value passes your validation logic
if(SomeCondtion(value))
{
// If yes, then set the value, and record down the old value.
SetValue(ValueProperty, value);
_oldValue = value;
}
else
{
// Else logic fails, set the value to old value.
SetValue(ValueProperty, _oldValue);
}
// Implement INotifyPropertyChanged to update the TextBox.
if(PropertyChanged != null)
PropertyChanged(this, new PropertyChangedEventArgs("Value"));
}
}
Once again, as you can see from my answer that you can still show code in your question to help others answer your question no matter how complex your solution may be (if you want a good answer, you need to put in the effort to ask a good question). My answer may not work for you but maybe it might give you some "Googling" directions. Hope it helps.
It looks like you are breaking binding when you set property value directly from code behind.
You shouldn't modify property that way. Use value coercion mechanism and validate input in the Coerce value callback.
After days of looking around and a lot of search i found the solution of my problem
After all validation done and assigning old value and updating the dependecy property, i need to cal UpdateTarget() method, to Update the value in my TextBox.
This is what explains the solution better
http://social.msdn.microsoft.com/forums/en-US/wpf/thread/c404360c-8e31-4a85-9762-0324ed8812ef/
I know this question was about TextBox but for RichTextBox you would use UpdateLayout().
rtb.AppendText("Text");
rtb.ScrollToEnd();
rtb.UpdateLayout();