Sic.Framework/MECF.Framework.UI.Client/Ctrlib/Controls/ComboTextBlock.cs

279 lines
10 KiB
C#
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

using System;
using System.Collections;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
namespace OpenSEMI.Ctrlib.Controls
{
public class ComboTextBlock : TextBlock
{
public EditBoxMode EditBoxMode
{
get { return (EditBoxMode)GetValue(EditBoxModeProperty); }
set { SetValue(EditBoxModeProperty, value); }
}
public static readonly DependencyProperty EditBoxModeProperty = DependencyProperty.Register("EditBoxMode", typeof(EditBoxMode), typeof(ComboTextBlock), new UIPropertyMetadata(EditBoxMode.Default));
private bool m_AllowEmpty = true;
public bool AllowEmpty
{
get { return m_AllowEmpty; }
set { m_AllowEmpty = value; }
}
/// <summary>
/// This is a flag to indicate that whether to change the bg color
/// when the text changed by backgroud not by GUI side.
/// This flag is true when control is bound to display text from dialog
/// </summary>
private bool m_AllowBackgroundChange = false;
public bool AllowBackgroundChange
{
get { return m_AllowBackgroundChange; }
set { m_AllowBackgroundChange = value; }
}
public static readonly DependencyProperty MaxValueProperty = DependencyProperty.Register("MaxValue", typeof(double), typeof(ComboTextBlock), new UIPropertyMetadata(double.NaN));
public double MaxValue
{
get { return (double)GetValue(MaxValueProperty); }
set { SetValue(MaxValueProperty, value); }
}
public double MinValue
{
get { return (double)GetValue(MinValueProperty); }
set { SetValue(MinValueProperty, value); }
}
public static readonly DependencyProperty MinValueProperty =
DependencyProperty.Register("MinValue", typeof(double), typeof(ComboTextBlock), new UIPropertyMetadata(double.NaN));
public Int32 Accuracy
{
get { return (Int32)GetValue(AccuracyProperty); }
set { SetValue(AccuracyProperty, value); }
}
public static readonly DependencyProperty AccuracyProperty =
DependencyProperty.Register("Accuracy", typeof(Int32), typeof(ComboTextBlock), new UIPropertyMetadata(4));
public bool TextSaved
{
get { return (bool)GetValue(TextSavedProperty); }
set { SetValue(TextSavedProperty, value); }
}
public static readonly DependencyProperty TextSavedProperty =
DependencyProperty.Register("TextSaved", typeof(bool), typeof(ComboTextBlock),
new UIPropertyMetadata(true, new PropertyChangedCallback(TextSavedChangedCallBack)));
public Boolean IsScrollToEnd
{
get { return (Boolean)GetValue(ScrollToEndProperty); }
set { SetValue(ScrollToEndProperty, value); }
}
public static readonly DependencyProperty ScrollToEndProperty =
DependencyProperty.Register("IsScrollToEnd", typeof(Boolean), typeof(ComboTextBlock), new UIPropertyMetadata(false));
private static void TextSavedChangedCallBack(DependencyObject d, DependencyPropertyChangedEventArgs args)
{
ComboTextBlock m_txt = d as ComboTextBlock;
if (m_txt != null)
{
//SetBGColor(m_txt);
}
}
public static readonly DependencyProperty ItemsSourceProperty =
DependencyProperty.Register("ItemsSource", typeof(IEnumerable), typeof(ComboTextBlock), new UIPropertyMetadata(null));
public IEnumerable ItemsSource
{
get
{
return (IEnumerable)GetValue(ItemsSourceProperty);
}
set
{
SetValue(ItemsSourceProperty, value);
}
}
public static readonly DependencyProperty SelectedItemProperty =
DependencyProperty.Register("SelectedItem", typeof(object), typeof(ComboTextBlock), new UIPropertyMetadata(null));
public object SelectedItem
{
get
{
return (object)GetValue(SelectedItemProperty);
}
set
{
SetValue(SelectedItemProperty, value);
}
}
public static readonly DependencyProperty IsInEditModeProperty =
DependencyProperty.Register("IsInEditMode", typeof(bool), typeof(ComboTextBlock), new UIPropertyMetadata(false, IsInEditModeUpdate));
public bool IsInEditMode
{
get
{
return (bool)GetValue(IsInEditModeProperty);
}
set
{
SetValue(IsInEditModeProperty, value);
}
}
public bool IsEditable
{
get { return (bool)GetValue(IsEditableProperty); }
set { SetValue(IsEditableProperty, value); }
}
public static readonly DependencyProperty IsEditableProperty =
DependencyProperty.Register("IsEditable", typeof(bool), typeof(ComboTextBlock),
new UIPropertyMetadata(false));
public bool IsLoopItem
{
get { return (bool)GetValue(IsLoopItemProperty); }
set { SetValue(IsLoopItemProperty, value); }
}
public static readonly DependencyProperty IsLoopItemProperty =
DependencyProperty.Register("IsLoopItem", typeof(bool), typeof(ComboTextBlock),
new UIPropertyMetadata(false));
private ComboTextBlockAdorner _adorner;
static ComboTextBlock()
{
DefaultStyleKeyProperty.OverrideMetadata(typeof(ComboTextBlock), new FrameworkPropertyMetadata(typeof(ComboTextBlock)));
}
private static void IsInEditModeUpdate(DependencyObject obj, DependencyPropertyChangedEventArgs e)
{
ComboTextBlock textBlock = obj as ComboTextBlock;
if (null != textBlock)
{
//Get the adorner layer of the uielement (here TextBlock)
AdornerLayer layer = AdornerLayer.GetAdornerLayer(textBlock);
if (layer == null)
return;
//If the IsInEditMode set to true means the user has enabled the edit mode then
//add the adorner to the adorner layer of the TextBlock.
if (textBlock.IsInEditMode)
{
if (null == textBlock._adorner)
{
textBlock._adorner = new ComboTextBlockAdorner(textBlock);
//Events wired to exit edit mode when the user presses Enter key or leaves the control.
//textBlock._adorner.TextBoxKeyUp += textBlock.TextBoxKeyUp;
//textBlock._adorner.TextBoxLostFocus += textBlock.TextBoxLostFocus;
}
layer.Add(textBlock._adorner);
}
else
{
//Remove the adorner from the adorner layer.
Adorner[] adorners = layer.GetAdorners(textBlock);
if (adorners != null)
{
foreach (Adorner adorner in adorners)
{
if (adorner is ComboTextBlockAdorner)
{
layer.Remove(adorner);
}
}
}
}
}
}
private void LeaveEditMode()
{
IsInEditMode = false;
//if (!IsLoopItem)
// Background = Brushes.Transparent;
}
public void TextBoxLostFocus(object sender, RoutedEventArgs e)
{
LeaveEditMode();
}
internal void DropDownClosedLostFocus(object sender, EventArgs e)
{
LeaveEditMode();
}
/// <summary>
/// release the edit mode when user presses enter.
/// </summary>
/// <param name="sender">The sender.</param>
/// <param name="e">The <see cref="System.Windows.Input.KeyEventArgs"/> instance containing the event data.</param>
private void TextBoxKeyUp(object sender, KeyEventArgs e)
{
if (e.Key == Key.Enter)
{
IsInEditMode = false;
//TextBoxEx atb = sender as TextBoxEx;
//if (atb == null)
// return;
//if (this.EditBoxMode == EditBoxMode.Decimal || this.EditBoxMode == EditBoxMode.UnSignDecimal ||
// this.EditBoxMode == EditBoxMode.SignInteger || this.EditBoxMode == EditBoxMode.UnSignInteger)
//{
// double dataValue = 0;
// if (!double.TryParse(atb.Text, out dataValue))
// return;
// if (MinValue == MaxValue && MinValue == 0)
// return;
// this.Background = (dataValue < MinValue || dataValue > MaxValue) ? Brushes.Red : Brushes.Transparent;
//}
}
}
/// <summary>
/// Invoked when an unhandled <see cref="E:System.Windows.Input.Mouse.MouseDown"/> attached event reaches an element in its route that is derived from this class. Implement this method to add class handling for this event.
/// </summary>
/// <param name="e">The <see cref="T:System.Windows.Input.MouseButtonEventArgs"/> that contains the event data. This event data reports details about the mouse button that was pressed and the handled state.</param>
protected override void OnMouseDown(MouseButtonEventArgs e)
{
if (e.MiddleButton == MouseButtonState.Pressed)
{
IsInEditMode = true;
}
else if (e.ClickCount == 1)
{
IsInEditMode = true;
}
}
}
}