X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=src%2FTizen.NUI%2Fsrc%2Fpublic%2FBaseComponents%2FTextField.cs;h=1d4d1ae5b90432d3535d8b19df7025a80f5784f8;hb=163d8156dc99b571242d87dcf63e772e4a91bb21;hp=1501cdb8b6201bc81a4688b2244f884b16eb313e;hpb=3fa7211d38b369f7a262cbeeaa4dc566ba35a8fe;p=platform%2Fcore%2Fcsapi%2Ftizenfx.git
diff --git a/src/Tizen.NUI/src/public/BaseComponents/TextField.cs b/src/Tizen.NUI/src/public/BaseComponents/TextField.cs
index 1501cdb..1d4d1ae 100755
--- a/src/Tizen.NUI/src/public/BaseComponents/TextField.cs
+++ b/src/Tizen.NUI/src/public/BaseComponents/TextField.cs
@@ -1,5 +1,5 @@
/*
- * Copyright(c) 2019 Samsung Electronics Co., Ltd.
+ * Copyright(c) 2021 Samsung Electronics Co., Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@@ -21,6 +21,7 @@ using System;
using System.Globalization;
using System.ComponentModel;
using Tizen.NUI.Binding;
+using Tizen.NUI.Text;
namespace Tizen.NUI.BaseComponents
{
@@ -35,9 +36,9 @@ namespace Tizen.NUI.BaseComponents
private string textFieldPlaceHolderTextFocusedSid = null;
private bool systemlangTextFlag = false;
private InputMethodContext inputMethodCotext = null;
- private TextFieldSelectorData selectorData;
private float fontSizeScale = 1.0f;
private bool hasFontSizeChangedCallback = false;
+ private bool isSettingTextInCSharp = false;
static TextField() { }
@@ -63,7 +64,7 @@ namespace Tizen.NUI.BaseComponents
}
///
- /// Get attribues, it is abstract function and must be override.
+ /// Get attributes, it is abstract function and must be override.
///
[EditorBrowsable(EditorBrowsableState.Never)]
protected override ViewStyle CreateViewStyle()
@@ -77,6 +78,8 @@ namespace Tizen.NUI.BaseComponents
{
SetVisible(false);
}
+
+ TextChanged += TextEditorTextChanged;
}
internal TextField(global::System.IntPtr cPtr, bool cMemoryOwn, bool shown = true) : base(cPtr, cMemoryOwn, null)
@@ -85,6 +88,8 @@ namespace Tizen.NUI.BaseComponents
{
SetVisible(false);
}
+
+ TextChanged += TextEditorTextChanged;
}
internal TextField(TextField handle, bool shown = true) : this(Interop.TextField.NewTextField(TextField.getCPtr(handle)), true)
@@ -95,6 +100,8 @@ namespace Tizen.NUI.BaseComponents
{
SetVisible(false);
}
+
+ TextChanged += TextEditorTextChanged;
}
internal enum ExceedPolicyType
@@ -119,7 +126,6 @@ namespace Tizen.NUI.BaseComponents
}
set
{
- selectorData?.TranslatableText?.Reset(this);
SetValue(TranslatableTextProperty, value);
}
}
@@ -158,7 +164,6 @@ namespace Tizen.NUI.BaseComponents
set
{
SetValue(TranslatablePlaceholderTextProperty, value);
- selectorData?.TranslatablePlaceholderText?.Reset(this);
}
}
private string translatablePlaceholderText
@@ -197,7 +202,6 @@ namespace Tizen.NUI.BaseComponents
set
{
SetValue(TranslatablePlaceholderTextFocusedProperty, value);
- selectorData?.TranslatablePlaceholderTextFocused?.Reset(this);
}
}
private string translatablePlaceholderTextFocused
@@ -230,8 +234,7 @@ namespace Tizen.NUI.BaseComponents
}
set
{
- SetValueAndForceSendChangeSignal(TextProperty, value);
- selectorData?.Text?.Reset(this);
+ SetValue(TextProperty, value);
NotifyPropertyChanged();
}
}
@@ -283,15 +286,21 @@ namespace Tizen.NUI.BaseComponents
set
{
SetValue(FontFamilyProperty, value);
- selectorData?.FontFamily?.Reset(this);
NotifyPropertyChanged();
}
}
///
/// The FontStyle property.
+ /// The fontStyle map contains the following keys :
+ ///
+ /// - width (string)The width key defines occupied by each glyph. (values: ultraCondensed, extraCondensed, condensed, semiCondensed, normal, semiExpanded, expanded, extraExpanded, ultraExpanded)
+ /// - weight (string)The weight key defines the thickness or darkness of the glyphs. (values: thin, ultraLight, extraLight, light, demiLight, semiLight, book, normal, regular, medium, demiBold, semiBold, bold, ultraBold, extraBold, black, heavy, extraBlack)
+ /// - slant (string)The slant key defines whether to use italics. (values: normal, roman, italic, oblique)
+ ///
///
/// 3
+ [System.Diagnostics.CodeAnalysis.SuppressMessage("Naming", "CA1721: Property names should not match get methods")]
public PropertyMap FontStyle
{
get
@@ -306,6 +315,42 @@ namespace Tizen.NUI.BaseComponents
}
///
+ /// Set FontStyle to TextField.
+ ///
+ /// The FontStyle
+ ///
+ /// SetFontStyle specifies the requested font style through .
+ ///
+ ///
+ /// The following example demonstrates how to use the SetFontStyle method.
+ ///
+ /// var fontStyle = new Tizen.NUI.Text.FontStyle();
+ /// fontStyle.Width = FontWidthType.Expanded;
+ /// fontStyle.Weight = FontWeightType.Bold;
+ /// fontStyle.Slant = FontSlantType.Italic;
+ /// field.SetFontStyle(fontStyle);
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public void SetFontStyle(FontStyle fontStyle)
+ {
+ SetValue(FontStyleProperty, TextUtils.GetFontStyleMap(fontStyle));
+ }
+
+ ///
+ /// Get FontStyle from TextField.
+ ///
+ /// The FontStyle
+ ///
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public FontStyle GetFontStyle()
+ {
+ return TextUtils.GetFontStyleStruct((PropertyMap)GetValue(FontStyleProperty));
+ }
+
+ ///
/// The PointSize property.
///
/// 3
@@ -318,7 +363,6 @@ namespace Tizen.NUI.BaseComponents
set
{
SetValue(PointSizeProperty, value);
- selectorData?.PointSize?.Reset(this);
NotifyPropertyChanged();
}
}
@@ -409,7 +453,6 @@ namespace Tizen.NUI.BaseComponents
set
{
SetValue(TextColorProperty, value);
- selectorData?.TextColor?.Reset(this);
NotifyPropertyChanged();
}
}
@@ -431,7 +474,6 @@ namespace Tizen.NUI.BaseComponents
set
{
SetValue(PlaceholderTextColorProperty, value);
- selectorData?.PlaceholderTextColor?.Reset(this);
NotifyPropertyChanged();
}
}
@@ -509,7 +551,6 @@ namespace Tizen.NUI.BaseComponents
set
{
SetValue(PrimaryCursorColorProperty, value);
- selectorData?.PrimaryCursorColor?.Reset(this);
NotifyPropertyChanged();
}
}
@@ -673,6 +714,10 @@ namespace Tizen.NUI.BaseComponents
///
/// The SelectionHandleImageLeft property.
+ /// The selectionHandleImageLeft map contains the following key :
+ ///
+ /// - filename (string)The path of image file
+ ///
///
/// 3
public PropertyMap SelectionHandleImageLeft
@@ -690,6 +735,10 @@ namespace Tizen.NUI.BaseComponents
///
/// The SelectionHandleImageRight property.
+ /// The selectionHandleImageRight map contains the following key :
+ ///
+ /// - filename (string)The path of image file
+ ///
///
/// 3
public PropertyMap SelectionHandleImageRight
@@ -706,7 +755,54 @@ namespace Tizen.NUI.BaseComponents
}
///
+ /// Set SelectionHandleImage to TextField.
+ ///
+ /// The SelectionHandleImage
+ ///
+ /// SetSelectionHandleImage specifies the display image used for the selection handle through .
+ ///
+ ///
+ /// The following example demonstrates how to use the SetSelectionHandleImage method.
+ ///
+ /// var selectionHandleImage = new Tizen.NUI.Text.SelectionHandleImage();
+ /// selectionHandleImage.LeftImageUrl = "handle_downleft.png";
+ /// selectionHandleImage.RightImageUrl = "handle_downright.png";
+ /// field.SetSelectionHandleImage(selectionHandleImage);
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public void SetSelectionHandleImage(SelectionHandleImage selectionHandleImage)
+ {
+ if (!String.IsNullOrEmpty(selectionHandleImage.LeftImageUrl))
+ {
+ SetValue(SelectionHandleImageLeftProperty, TextUtils.GetFileNameMap(selectionHandleImage.LeftImageUrl));
+ }
+
+ if (!String.IsNullOrEmpty(selectionHandleImage.RightImageUrl))
+ {
+ SetValue(SelectionHandleImageRightProperty, TextUtils.GetFileNameMap(selectionHandleImage.RightImageUrl));
+ }
+ }
+
+ ///
+ /// Get SelectionHandleImage from TextField.
+ ///
+ /// The SelectionHandleImage
+ ///
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public SelectionHandleImage GetSelectionHandleImage()
+ {
+ return TextUtils.GetSelectionHandleImageStruct((PropertyMap)GetValue(SelectionHandleImageLeftProperty), (PropertyMap)GetValue(SelectionHandleImageRightProperty));
+ }
+
+ ///
/// The SelectionHandlePressedImageLeft property.
+ /// The selectionHandlePressedImageLeft map contains the following key :
+ ///
+ /// - filename (string)The path of image file
+ ///
///
/// 3
public PropertyMap SelectionHandlePressedImageLeft
@@ -724,6 +820,10 @@ namespace Tizen.NUI.BaseComponents
///
/// The SelectionHandlePressedImageRight property.
+ /// The selectionHandlePressedImageRight map contains the following key :
+ ///
+ /// - filename (string)The path of image file
+ ///
///
/// 3
public PropertyMap SelectionHandlePressedImageRight
@@ -740,7 +840,54 @@ namespace Tizen.NUI.BaseComponents
}
///
+ /// Set SelectionHandlePressedImage to TextField.
+ ///
+ /// The SelectionHandleImage
+ ///
+ /// SetSelectionHandlePressedImage specifies the display image used for the selection handle through .
+ ///
+ ///
+ /// The following example demonstrates how to use the SetSelectionHandlePressedImage method.
+ ///
+ /// var selectionHandlePressedImage = new Tizen.NUI.Text.SelectionHandleImage();
+ /// selectionHandlePressedImage.LeftImageUrl = "handle_pressed_downleft.png";
+ /// selectionHandlePressedImage.RightImageUrl = "handle_pressed_downright.png";
+ /// field.SetSelectionHandlePressedImage(selectionHandlePressedImage);
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public void SetSelectionHandlePressedImage(SelectionHandleImage selectionHandlePressedImage)
+ {
+ if (!String.IsNullOrEmpty(selectionHandlePressedImage.LeftImageUrl))
+ {
+ SetValue(SelectionHandlePressedImageLeftProperty, TextUtils.GetFileNameMap(selectionHandlePressedImage.LeftImageUrl));
+ }
+
+ if (!String.IsNullOrEmpty(selectionHandlePressedImage.RightImageUrl))
+ {
+ SetValue(SelectionHandlePressedImageRightProperty, TextUtils.GetFileNameMap(selectionHandlePressedImage.RightImageUrl));
+ }
+ }
+
+ ///
+ /// Get SelectionHandlePressedImage from TextField.
+ ///
+ /// The SelectionHandlePressedImage
+ ///
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public SelectionHandleImage GetSelectionHandlePressedImage()
+ {
+ return TextUtils.GetSelectionHandleImageStruct((PropertyMap)GetValue(SelectionHandlePressedImageLeftProperty), (PropertyMap)GetValue(SelectionHandlePressedImageRightProperty));
+ }
+
+ ///
/// The SelectionHandleMarkerImageLeft property.
+ /// The selectionHandleMarkerImageLeft map contains the following key :
+ ///
+ /// - filename (string)The path of image file
+ ///
///
/// 3
public PropertyMap SelectionHandleMarkerImageLeft
@@ -758,6 +905,10 @@ namespace Tizen.NUI.BaseComponents
///
/// The SelectionHandleMarkerImageRight property.
+ /// The selectionHandleMarkerImageRight map contains the following key :
+ ///
+ /// - filename (string)The path of image file
+ ///
///
/// 3
public PropertyMap SelectionHandleMarkerImageRight
@@ -774,6 +925,49 @@ namespace Tizen.NUI.BaseComponents
}
///
+ /// Set SelectionHandleMarkerImage to TextField.
+ ///
+ /// The SelectionHandleImage
+ ///
+ /// SetSelectionHandleMarkerImage specifies the display image used for the selection handle through .
+ ///
+ ///
+ /// The following example demonstrates how to use the SetSelectionHandleMarkerImage method.
+ ///
+ /// var selectionHandleMarkerImage = new Tizen.NUI.Text.SelectionHandleImage();
+ /// selectionHandleMarkerImage.LeftImageUrl = "handle_pressed_downleft.png";
+ /// selectionHandleMarkerImage.RightImageUrl = "handle_pressed_downright.png";
+ /// field.SetSelectionHandleMarkerImage(selectionHandleMarkerImage);
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public void SetSelectionHandleMarkerImage(SelectionHandleImage selectionHandleMarkerImage)
+ {
+ if (!String.IsNullOrEmpty(selectionHandleMarkerImage.LeftImageUrl))
+ {
+ SetValue(SelectionHandleMarkerImageLeftProperty, TextUtils.GetFileNameMap(selectionHandleMarkerImage.LeftImageUrl));
+ }
+
+ if (!String.IsNullOrEmpty(selectionHandleMarkerImage.RightImageUrl))
+ {
+ SetValue(SelectionHandleMarkerImageRightProperty, TextUtils.GetFileNameMap(selectionHandleMarkerImage.RightImageUrl));
+ }
+ }
+
+ ///
+ /// Get SelectionHandleMarkerImage from TextField.
+ ///
+ /// The SelectionHandleMarkerImage
+ ///
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public SelectionHandleImage GetSelectionHandleMarkerImage()
+ {
+ return TextUtils.GetSelectionHandleImageStruct((PropertyMap)GetValue(SelectionHandleMarkerImageLeftProperty), (PropertyMap)GetValue(SelectionHandleMarkerImageRightProperty));
+ }
+
+ ///
/// The SelectionHighlightColor property.
///
///
@@ -818,6 +1012,20 @@ namespace Tizen.NUI.BaseComponents
///
/// The InputMethodSettings property.
///
+ ///
+ /// is a class encapsulating the input method map. Please use the class for this property.
+ ///
+ ///
+ /// The following example demonstrates how to set the InputMethodSettings property.
+ ///
+ /// InputMethod method = new InputMethod();
+ /// method.PanelLayout = InputMethod.PanelLayoutType.Normal;
+ /// method.ActionButton = InputMethod.ActionButtonTitleType.Default;
+ /// method.AutoCapital = InputMethod.AutoCapitalType.Word;
+ /// method.Variation = 1;
+ /// textField.InputMethodSettings = method.OutputMap;
+ ///
+ ///
/// 3
public PropertyMap InputMethodSettings
{
@@ -889,8 +1097,15 @@ namespace Tizen.NUI.BaseComponents
///
/// The InputFontStyle property.
+ /// The inputFontStyle map contains the following keys :
+ ///
+ /// - width (string)The width key defines occupied by each glyph. (values: ultraCondensed, extraCondensed, condensed, semiCondensed, normal, semiExpanded, expanded, extraExpanded, ultraExpanded)
+ /// - weight (string)The weight key defines the thickness or darkness of the glyphs. (values: thin, ultraLight, extraLight, light, demiLight, semiLight, book, normal, regular, medium, demiBold, semiBold, bold, ultraBold, extraBold, black, heavy, extraBlack)
+ /// - slant (string)The slant key defines whether to use italics. (values: normal, roman, italic, oblique)
+ ///
///
/// 3
+ [System.Diagnostics.CodeAnalysis.SuppressMessage("Naming", "CA1721: Property names should not match get methods")]
public PropertyMap InputFontStyle
{
get
@@ -905,6 +1120,42 @@ namespace Tizen.NUI.BaseComponents
}
///
+ /// Set InputFontStyle to TextField.
+ ///
+ /// The FontStyle
+ ///
+ /// SetInputFontStyle specifies the requested font style for new input text through .
+ ///
+ ///
+ /// The following example demonstrates how to use the SetInputFontStyle method.
+ ///
+ /// var fontStyle = new Tizen.NUI.Text.FontStyle();
+ /// fontStyle.Width = FontWidthType.Expanded;
+ /// fontStyle.Weight = FontWeightType.Bold;
+ /// fontStyle.Slant = FontSlantType.Italic;
+ /// field.SetInputFontStyle(fontStyle);
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public void SetInputFontStyle(FontStyle fontStyle)
+ {
+ SetValue(InputFontStyleProperty, TextUtils.GetFontStyleMap(fontStyle));
+ }
+
+ ///
+ /// Get InputFontStyle from TextField.
+ ///
+ /// The FontStyle
+ ///
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public FontStyle GetInputFontStyle()
+ {
+ return TextUtils.GetFontStyleStruct((PropertyMap)GetValue(InputFontStyleProperty));
+ }
+
+ ///
/// The InputPointSize property.
///
/// 3
@@ -923,8 +1174,15 @@ namespace Tizen.NUI.BaseComponents
///
/// The Underline property.
+ /// The underline map contains the following keys :
+ ///
+ /// - enable (bool)Whether the underline is enabled (the default value is false)
+ /// - color (Color)The color of the underline (If not provided then the color of the text is used)
+ /// - height (float)The height in pixels of the underline (the default value is 1.f)
+ ///
///
/// 3
+ [System.Diagnostics.CodeAnalysis.SuppressMessage("Naming", "CA1721: Property names should not match get methods")]
public PropertyMap Underline
{
get
@@ -939,6 +1197,42 @@ namespace Tizen.NUI.BaseComponents
}
///
+ /// Set Underline to TextField.
+ ///
+ /// The Underline
+ ///
+ /// SetUnderline specifies the underline of the text through .
+ ///
+ ///
+ /// The following example demonstrates how to use the SetUnderline method.
+ ///
+ /// var underline = new Tizen.NUI.Text.Underline();
+ /// underline.Enable = true;
+ /// underline.Color = new Color("#3498DB");
+ /// underline.Height = 2.0f;
+ /// field.SetUnderline(underline);
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public void SetUnderline(Underline underline)
+ {
+ SetValue(UnderlineProperty, TextUtils.GetUnderlineMap(underline));
+ }
+
+ ///
+ /// Get Underline from TextField.
+ ///
+ /// The Underline
+ ///
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public Underline GetUnderline()
+ {
+ return TextUtils.GetUnderlineStruct((PropertyMap)GetValue(UnderlineProperty));
+ }
+
+ ///
/// The InputUnderline property.
///
/// 3
@@ -957,8 +1251,15 @@ namespace Tizen.NUI.BaseComponents
///
/// The Shadow property.
+ /// The shadow map contains the following keys :
+ ///
+ /// - color (Color)The color of the shadow (the default color is Color.Black)
+ /// - offset (Vector2)The offset in pixels of the shadow (If not provided then the shadow is not enabled)
+ /// - blurRadius (float)The radius of the Gaussian blur for the soft shadow (If not provided then the soft shadow is not enabled)
+ ///
///
/// 3
+ [System.Diagnostics.CodeAnalysis.SuppressMessage("Naming", "CA1721: Property names should not match get methods")]
public PropertyMap Shadow
{
get
@@ -973,6 +1274,41 @@ namespace Tizen.NUI.BaseComponents
}
///
+ /// Set Shadow to TextField.
+ ///
+ /// The Shadow
+ ///
+ /// SetShadow specifies the shadow of the text through .
+ ///
+ ///
+ /// The following example demonstrates how to use the SetShadow method.
+ ///
+ /// var shadow = new Tizen.NUI.Text.Shadow();
+ /// shadow.Offset = new Vector2(3, 3);
+ /// shadow.Color = new Color("#F1C40F");
+ /// field.SetShadow(shadow);
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public void SetShadow(Tizen.NUI.Text.Shadow shadow)
+ {
+ SetValue(ShadowProperty, TextUtils.GetShadowMap(shadow));
+ }
+
+ ///
+ /// Get Shadow from TextField.
+ ///
+ /// The Shadow
+ ///
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public Tizen.NUI.Text.Shadow GetShadow()
+ {
+ return TextUtils.GetShadowStruct((PropertyMap)GetValue(ShadowProperty));
+ }
+
+ ///
/// The InputShadow property.
///
/// 3
@@ -1025,8 +1361,14 @@ namespace Tizen.NUI.BaseComponents
///
/// The Outline property.
+ /// The outline map contains the following keys :
+ ///
+ /// - color (Color)The color of the outline (the default color is Color.White)
+ /// - width (float)The width in pixels of the outline (If not provided then the outline is not enabled)
+ ///
///
/// 3
+ [System.Diagnostics.CodeAnalysis.SuppressMessage("Naming", "CA1721: Property names should not match get methods")]
public PropertyMap Outline
{
get
@@ -1041,6 +1383,41 @@ namespace Tizen.NUI.BaseComponents
}
///
+ /// Set Outline to TextField.
+ ///
+ /// The Outline
+ ///
+ /// SetOutline specifies the outline of the text through .
+ ///
+ ///
+ /// The following example demonstrates how to use the SetOutline method.
+ ///
+ /// var outline = new Tizen.NUI.Text.Outline();
+ /// outline.Width = 2.0f;
+ /// outline.Color = new Color("#45B39D");
+ /// field.SetOutline(outline);
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public void SetOutline(Outline outline)
+ {
+ SetValue(OutlineProperty, TextUtils.GetOutlineMap(outline));
+ }
+
+ ///
+ /// Get Outline from TextField.
+ ///
+ /// The Outline
+ ///
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public Outline GetOutline()
+ {
+ return TextUtils.GetOutlineStruct((PropertyMap)GetValue(OutlineProperty));
+ }
+
+ ///
/// The InputOutline property.
///
/// 3
@@ -1059,7 +1436,27 @@ namespace Tizen.NUI.BaseComponents
///
/// The HiddenInputSettings property.
+ /// The hiddenInputSettings map contains the following keys :
+ ///
+ /// - HiddenInputProperty.Mode (int)The mode for input text display (Use HiddenInputModeType)
+ /// - HiddenInputProperty.SubstituteCharacter (int)All input characters are substituted by this character
+ /// - HiddenInputProperty.SubstituteCount (int)Length of text to show or hide, available when HideCount/ShowCount mode is used
+ /// - HiddenInputProperty.ShowLastCharacterDuration (int)Hide last character after this duration, available when ShowLastCharacter mode
+ ///
///
+ ///
+ /// See and for a detailed description.
+ ///
+ ///
+ /// The following example demonstrates how to set the HiddenInputSettings property.
+ ///
+ /// PropertyMap map = new PropertyMap();
+ /// map.Add(HiddenInputProperty.Mode, new PropertyValue((int)HiddenInputModeType.ShowLastCharacter));
+ /// map.Add(HiddenInputProperty.ShowLastCharacterDuration, new PropertyValue(500));
+ /// map.Add(HiddenInputProperty.SubstituteCharacter, new PropertyValue(0x2A));
+ /// textField.HiddenInputSettings = map;
+ ///
+ ///
/// 3
public Tizen.NUI.PropertyMap HiddenInputSettings
{
@@ -1075,6 +1472,43 @@ namespace Tizen.NUI.BaseComponents
}
///
+ /// Set HiddenInput to TextField.
+ ///
+ /// The HiddenInput
+ ///
+ /// SetHiddenInput specifies the requested font style through .
+ ///
+ ///
+ /// The following example demonstrates how to use the SetHiddenInput method.
+ ///
+ /// var hiddenInput = new Tizen.NUI.Text.HiddenInput();
+ /// hiddenInput.Mode = HiddenInputModeType.ShowLastCharacter;
+ /// hiddenInput.SubstituteCharacter = 'â
';
+ /// hiddenInput.SubstituteCount = 0;
+ /// hiddenInput.ShowLastCharacterDuration = 1000;
+ /// field.SetHiddenInput(hiddenInput);
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public void SetHiddenInput(HiddenInput hiddenInput)
+ {
+ SetValue(HiddenInputSettingsProperty, TextUtils.GetHiddenInputMap(hiddenInput));
+ }
+
+ ///
+ /// Get HiddenInput from TextField.
+ ///
+ /// The HiddenInput
+ ///
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public HiddenInput GetHiddenInput()
+ {
+ return TextUtils.GetHiddenInputStruct((PropertyMap)GetValue(HiddenInputSettingsProperty));
+ }
+
+ ///
/// The PixelSize property.
///
/// 3
@@ -1087,7 +1521,6 @@ namespace Tizen.NUI.BaseComponents
set
{
SetValue(PixelSizeProperty, value);
- selectorData?.PixelSize?.Reset(this);
NotifyPropertyChanged();
}
}
@@ -1148,11 +1581,12 @@ namespace Tizen.NUI.BaseComponents
}
///
- /// The Selected Text property.
+ /// The portion of the text that has been selected by the user.
///
- /// 8
- /// This will be public opened in tizen_6.0 after ACR done, Before ACR, need to be hidden as inhouse API.
- [EditorBrowsable(EditorBrowsableState.Never)]
+ ///
+ /// Empty string when nothing is selected.
+ ///
+ /// 9
public string SelectedText
{
get
@@ -1166,9 +1600,10 @@ namespace Tizen.NUI.BaseComponents
///
/// The start index for selection.
///
- /// 8
- /// This will be public opened in tizen_6.0 after ACR done, Before ACR, need to be hidden as inhouse API.
- [EditorBrowsable(EditorBrowsableState.Never)]
+ ///
+ /// When there is no selection, the index is current cursor position.
+ ///
+ /// 9
public int SelectedTextStart
{
get
@@ -1177,19 +1612,15 @@ namespace Tizen.NUI.BaseComponents
GetProperty(TextField.Property.SelectedTextStart).Get(out temp);
return temp;
}
- set
- {
- SetProperty(TextField.Property.SelectedTextStart, new PropertyValue(value));
- NotifyPropertyChanged();
- }
}
///
/// The end index for selection.
///
- /// 8
- /// This will be public opened in tizen_6.0 after ACR done, Before ACR, need to be hidden as inhouse API.
- [EditorBrowsable(EditorBrowsableState.Never)]
+ ///
+ /// When there is no selection, the index is current cursor position.
+ ///
+ /// 9
public int SelectedTextEnd
{
get
@@ -1198,11 +1629,6 @@ namespace Tizen.NUI.BaseComponents
GetProperty(TextField.Property.SelectedTextEnd).Get(out temp);
return temp;
}
- set
- {
- SetProperty(TextField.Property.SelectedTextEnd, new PropertyValue(value));
- NotifyPropertyChanged();
- }
}
///
@@ -1252,8 +1678,103 @@ namespace Tizen.NUI.BaseComponents
}
///
+ /// The GrabHandleColor property.
+ ///
+ ///
+ /// The property cascade chaining set is possible. For example, this (textField.GrabHandleColor.X = 0.1f;) is possible.
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public Color GrabHandleColor
+ {
+ get
+ {
+ Color temp = (Color)GetValue(GrabHandleColorProperty);
+ return new Color(OnGrabHandleColorChanged, temp.R, temp.G, temp.B, temp.A);
+ }
+ set
+ {
+ SetValue(GrabHandleColorProperty, value);
+ NotifyPropertyChanged();
+ }
+ }
+
+ ///
+ /// The ellipsis position of the text.
+ /// Specifies which portion of the text should be replaced with an ellipsis when the text size exceeds the layout size.
+ ///
+ /// 9
+ public EllipsisPosition EllipsisPosition
+ {
+ get
+ {
+ return (EllipsisPosition)GetValue(EllipsisPositionProperty);
+ }
+ set
+ {
+ SetValue(EllipsisPositionProperty, value);
+ NotifyPropertyChanged();
+ }
+ }
+
+ ///
+ /// Set InputFilter to TextField.
+ ///
+ /// The InputFilter
+ ///
+ /// filters input based on regular expressions.
+ /// Users can set the Accepted or Rejected regular expression set, or both.
+ /// If both are used, Rejected has higher priority.
+ /// The character set must follow the regular expression rules.
+ /// Behaviour can not be guaranteed for incorrect grammars.
+ /// Refer the link below for detailed rules.
+ /// The functions in std::regex library use the ECMAScript grammar:
+ /// http://cplusplus.com/reference/regex/ECMAScript/
+ /// InputFiltered signal is emitted when the input is filtered by InputFilter
+ /// See , and for a detailed description.
+ ///
+ ///
+ /// The following example demonstrates how to use the SetInputFilter method.
+ ///
+ /// var inputFilter = new Tizen.NUI.Text.InputFilter();
+ /// inputFilter.Accepted = @"[\d]"; // accept whole digits
+ /// inputFilter.Rejected = "[0-3]"; // reject 0, 1, 2, 3
+ /// field.SetInputFilter(inputFilter); // acceptable inputs are 4, 5, 6, 7, 8, 9
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public void SetInputFilter(InputFilter inputFilter)
+ {
+ SetProperty(TextField.Property.InputFilter, new PropertyValue(TextUtils.GetInputFilterMap(inputFilter)));
+ }
+
+ ///
+ /// Get InputFilter from TextField.
+ ///
+ /// The InputFilter
+ ///
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public InputFilter GetInputFilter()
+ {
+ var map = new PropertyMap();
+ GetProperty(TextField.Property.InputFilter).Get(map);
+ return TextUtils.GetInputFilterStruct(map);
+ }
+
+ ///
/// The Placeholder property.
- /// Gets or sets the placeholder: text, color, font family, font style, point size, and pixel size.
+ /// The placeholder map contains the following keys :
+ ///
+ /// - text (string)The text to display when the TextField is empty and inactive
+ /// - textFocused (string)The text to display when the placeholder has focus
+ /// - color (Color)The color of the placeholder text
+ /// - fontFamily (string)The fontFamily of the placeholder text
+ /// - fontStyle (PropertyMap)The fontStyle of the placeholder text
+ /// - pointSize (float)The pointSize of the placeholder text
+ /// - pixelSize (float)The pixelSize of the placeholder text
+ /// - ellipsis (bool)The ellipsis of the placeholder text
+ ///
///
///
/// The following example demonstrates how to set the Placeholder property.
@@ -1276,11 +1797,81 @@ namespace Tizen.NUI.BaseComponents
///
///
/// 3
+ [System.Diagnostics.CodeAnalysis.SuppressMessage("Naming", "CA1721: Property names should not match get methods")]
public Tizen.NUI.PropertyMap Placeholder
{
get
{
- return (PropertyMap)GetValue(PlaceholderProperty);
+ PropertyMap map = (PropertyMap)GetValue(PlaceholderProperty);
+ PropertyValue value = null;
+
+ // text
+ value = map.Find(0);
+ if (null != value)
+ {
+ value.Get(out string text);
+ map.Add("text", new PropertyValue(text));
+ }
+
+ // textFocused
+ value = map.Find(1);
+ if (null != value)
+ {
+ value.Get(out string textFocused);
+ map.Add("textFocused", new PropertyValue(textFocused));
+ }
+
+ // color
+ value = map.Find(2);
+ if (null != value)
+ {
+ Color color = new Color();
+ value.Get(color);
+ map.Add("color", new PropertyValue(color));
+ }
+
+ // fontFamily
+ value = map.Find(3);
+ if (null != value)
+ {
+ value.Get(out string fontFamily);
+ map.Add("fontFamily", new PropertyValue(fontFamily));
+ }
+
+ // fontStyle
+ value = map.Find(4);
+ if (null != value)
+ {
+ PropertyMap fontStyle = new PropertyMap();
+ value.Get(fontStyle);
+ map.Add("fontStyle", new PropertyValue(fontStyle));
+ }
+
+ // pointSize
+ value = map.Find(5);
+ if (null != value)
+ {
+ value.Get(out float pointSize);
+ map.Add("pointSize", new PropertyValue(pointSize));
+ }
+
+ // pixelSize
+ value = map.Find(6);
+ if (null != value)
+ {
+ value.Get(out float pixelSize);
+ map.Add("pixelSize", new PropertyValue(pixelSize));
+ }
+
+ // ellipsis
+ value = map.Find(7);
+ if (null != value)
+ {
+ value.Get(out bool ellipsis);
+ map.Add("ellipsis", new PropertyValue(ellipsis));
+ }
+
+ return map;
}
set
{
@@ -1290,6 +1881,52 @@ namespace Tizen.NUI.BaseComponents
}
///
+ /// Set Placeholder to TextField.
+ ///
+ /// The Placeholder
+ ///
+ /// SetPlaceholder specifies the attributes of the placeholder property through .
+ ///
+ ///
+ /// The following example demonstrates how to use the SetPlaceholder method.
+ ///
+ /// var placeholder = new Tizen.NUI.Text.Placeholder();
+ /// placeholder.Text = "placeholder text";
+ /// placeholder.TextFocused = "placeholder textFocused";
+ /// placeholder.Color = new Color("#45B39D");
+ /// placeholder.FontFamily = "BreezeSans";
+ /// placeholder.FontStyle = new Tizen.NUI.Text.FontStyle()
+ /// {
+ /// Width = FontWidthType.Expanded,
+ /// Weight = FontWeightType.ExtraLight,
+ /// Slant = FontSlantType.Italic,
+ /// };
+ /// placeholder.PointSize = 25.0f;
+ /// //placeholder.PixelSize = 50.0f;
+ /// placeholder.Ellipsis = true;
+ /// field.SetPlaceholder(placeholder);
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public void SetPlaceholder(Placeholder placeholder)
+ {
+ SetValue(PlaceholderProperty, TextUtils.GetPlaceholderMap(placeholder));
+ }
+
+ ///
+ /// Get Placeholder from TextField.
+ ///
+ /// The Placeholder
+ ///
+ ///
+ ///
+ [EditorBrowsable(EditorBrowsableState.Never)]
+ public Placeholder GetPlaceholder()
+ {
+ return TextUtils.GetPlaceholderStruct((PropertyMap)GetValue(PlaceholderProperty));
+ }
+
+ ///
/// The Ellipsis property.
/// Enable or disable the ellipsis.
/// Placeholder PropertyMap is used to add ellipsis to placeholder text.
@@ -1390,30 +2027,6 @@ namespace Tizen.NUI.BaseComponents
}
}
- /// Only used by the IL of xaml, will never changed to not hidden.
- [EditorBrowsable(EditorBrowsableState.Never)]
- public override bool IsCreateByXaml
- {
- get
- {
- return base.IsCreateByXaml;
- }
- set
- {
- base.IsCreateByXaml = value;
-
- if (value == true)
- {
- this.TextChanged += (obj, e) =>
- {
- this.Text = e.TextField.Text;
- };
- }
- }
- }
-
- private TextFieldSelectorData EnsureSelectorData() => selectorData ?? (selectorData = new TextFieldSelectorData());
-
///
/// Get the InputMethodContext instance.
///
@@ -1433,9 +2046,7 @@ namespace Tizen.NUI.BaseComponents
///
/// Select the whole text.
///
- /// 6
- /// This will be released at Tizen.NET API Level 5.5, so currently this would be used as inhouse API.
- [EditorBrowsable(EditorBrowsableState.Never)]
+ /// 9
public void SelectWholeText()
{
Interop.TextField.SelectWholeText(SwigCPtr);
@@ -1443,20 +2054,35 @@ namespace Tizen.NUI.BaseComponents
}
///
- /// Clear selection of the text.
+ /// Select text from start to end index.
+ /// The index is valid when 0 or positive.
///
- /// 8
- /// This will be public opened in tizen_6.0 after ACR done, Before ACR, need to be hidden as inhouse API.
- [EditorBrowsable(EditorBrowsableState.Never)]
- public void SelectNone()
+ /// The start index for selection.
+ /// The end index for selection.
+ ///
+ /// If the end index exceeds the maximum value, it is set to the length of the text.
+ ///
+ /// 9
+ public void SelectText(int start, int end)
{
- _ = Interop.TextField.SelectNone(SwigCPtr);
+ if (start < 0)
+ throw new global::System.ArgumentOutOfRangeException(nameof(start), "Value is less than zero");
+ if (end < 0)
+ throw new global::System.ArgumentOutOfRangeException(nameof(end), "Value is less than zero");
+
+ Interop.TextField.SelectText(SwigCPtr, (uint)start, (uint)end);
if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
}
- internal static global::System.Runtime.InteropServices.HandleRef getCPtr(TextField obj)
+ ///
+ /// Clear selection of the text.
+ /// Valid when selection is activate.
+ ///
+ /// 9
+ public void SelectNone()
{
- return (obj == null) ? new global::System.Runtime.InteropServices.HandleRef(null, global::System.IntPtr.Zero) : obj.SwigCPtr;
+ _ = Interop.TextField.SelectNone(SwigCPtr);
+ if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
}
internal SWIGTYPE_p_Dali__SignalT_void_fDali__Toolkit__TextField_Dali__Toolkit__TextField__InputStyle__MaskF_t InputStyleChangedSignal()
@@ -1490,7 +2116,6 @@ namespace Tizen.NUI.BaseComponents
//Called by User
//Release your own managed resources here.
//You should release all of your own disposable objects here.
- selectorData?.Reset(this);
}
//Release your own unmanaged resources here.
@@ -1498,17 +2123,34 @@ namespace Tizen.NUI.BaseComponents
//because the execution order of Finalizes is non-deterministic.
if (this.HasBody())
{
+ if (textFieldCursorPositionChangedCallbackDelegate != null)
+ {
+ this.CursorPositionChangedSignal().Disconnect(textFieldCursorPositionChangedCallbackDelegate);
+ }
+
if (textFieldMaxLengthReachedCallbackDelegate != null)
{
this.MaxLengthReachedSignal().Disconnect(textFieldMaxLengthReachedCallbackDelegate);
}
+ if (textFieldSelectionClearedCallbackDelegate != null)
+ {
+ this.SelectionClearedSignal().Disconnect(textFieldSelectionClearedCallbackDelegate);
+ }
+
+ if (textFieldSelectionChangedCallbackDelegate != null)
+ {
+ this.SelectionChangedSignal().Disconnect(textFieldSelectionChangedCallbackDelegate);
+ }
+
if (textFieldTextChangedCallbackDelegate != null)
{
TextChangedSignal().Disconnect(textFieldTextChangedCallbackDelegate);
}
}
+ TextChanged -= TextEditorTextChanged;
+
base.Dispose(type);
}
@@ -1598,6 +2240,14 @@ namespace Tizen.NUI.BaseComponents
}
}
+ private void TextEditorTextChanged(object sender, TextChangedEventArgs e)
+ {
+ if (!isSettingTextInCSharp)
+ {
+ EnforceNotifyBindedInstance(TextProperty);
+ }
+ }
+
internal new class Property
{
internal static readonly int TEXT = Interop.TextField.TextGet();
@@ -1659,6 +2309,9 @@ namespace Tizen.NUI.BaseComponents
internal static readonly int EnableEditing = Interop.TextField.EnableEditingGet();
internal static readonly int PrimaryCursorPosition = Interop.TextField.PrimaryCursorPositionGet();
internal static readonly int FontSizeScale = Interop.TextField.FontSizeScaleGet();
+ internal static readonly int GrabHandleColor = Interop.TextField.GrabHandleColorGet();
+ internal static readonly int EllipsisPosition = Interop.TextField.EllipsisPositionGet();
+ internal static readonly int InputFilter = Interop.TextField.InputFilterGet();
}
internal class InputStyle
@@ -1713,5 +2366,9 @@ namespace Tizen.NUI.BaseComponents
{
TextColor = new Color(r, g, b, a);
}
+ private void OnGrabHandleColorChanged(float r, float g, float b, float a)
+ {
+ GrabHandleColor = new Color(r, g, b, a);
+ }
}
}