modern - ui framework c#
Mostrando una pista para un control de ediciĆ³n de C winforms (5)
Estoy trabajando en una aplicación C # winforms (VS.NET 2008, .NET 3.5 sp 1). Tengo un campo de búsqueda en un formulario, y en lugar de tener una etiqueta al lado del campo de búsqueda, me gustaría mostrar un texto gris en el fondo del campo de búsqueda mismo (''Términos de búsqueda'', por ejemplo). Cuando el usuario comienza a ingresar texto en el campo de búsqueda, el texto debería desaparecer. ¿Cómo puedo conseguir esto?
Creo que la manera en que esto se hace generalmente es establecer el color del texto en gris y rellenarlo con su texto de sugerencia.
Luego, escriba manejadores para los eventos de enfoque del campo de texto, modificando el contenido de los campos y el color cuando se gana y pierde el enfoque. Aquí hay un pseudocódigo (lo siento, no es un código C #. Tengo Actionscript en el cerebro en este momento):
TextInput myInput;
boolean showingHint = true;
myInput.text = "Search Terms";
myInput.color = 0xcccccc;
myInput.onFocusGained = function() {
if(showingHint) {
myInput.text = "";
myInput.color = 0x000000;
showingHint = false;
}
}
myInput.onFocusLost = function() {
if(!showingHint && myInput.text.length == 0) {
myInput.text = "Search Terms";
myInput.color = 0xcccccc;
showingHint = true;
}
}
Recuerde, solo desea cambiar el texto del enfoque perdido si el usuario no ha cambiado el texto manualmente. Use un booleano por separado para rastrear si está mostrando la sugerencia o no, para que pueda diferenciar entre el usuario que escribe manualmente su texto de "sugerencia" como contenido real. De forma similar, solo desea borrar el contenido del cuadro de entrada si se muestra la sugerencia para que no se deshaga accidentalmente de la entrada del usuario.
Es mejor publicar el código en lugar del enlace. Estoy publicando esto desde aquí
//Copyright (c) 2008 Jason Kemp
//Permission is hereby granted, free of charge, to any person obtaining a copy
//of this software and associated documentation files (the "Software"), to deal
//in the Software without restriction, including without limitation the rights
//to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
//copies of the Software, and to permit persons to whom the Software is
//furnished to do so, subject to the following conditions:
//The above copyright notice and this permission notice shall be included in
//all copies or substantial portions of the Software.
//THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
//IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
//FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
//AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
//LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
//OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
//THE SOFTWARE.
using System;
using System.Runtime.InteropServices;
using System.Windows.Forms;
using System.Text;
public static class Win32Utility
{
[DllImport("user32.dll", CharSet = CharSet.Auto)]
private static extern Int32 SendMessage(IntPtr hWnd, int msg,
int wParam, [MarshalAs(UnmanagedType.LPWStr)] string lParam);
[DllImport("user32.dll")]
private static extern bool SendMessage(IntPtr hwnd, int msg, int wParam, StringBuilder lParam);
[DllImport("user32.dll")]
private static extern bool GetComboBoxInfo(IntPtr hwnd, ref COMBOBOXINFO pcbi);
[StructLayout(LayoutKind.Sequential)]
private struct COMBOBOXINFO
{
public int cbSize;
public RECT rcItem;
public RECT rcButton;
public IntPtr stateButton;
public IntPtr hwndCombo;
public IntPtr hwndItem;
public IntPtr hwndList;
}
[StructLayout(LayoutKind.Sequential)]
private struct RECT
{
public int left;
public int top;
public int right;
public int bottom;
}
private const int EM_SETCUEBANNER = 0x1501;
private const int EM_GETCUEBANNER = 0x1502;
public static void SetCueText(Control control, string text)
{
if (control is ComboBox)
{
COMBOBOXINFO info = GetComboBoxInfo(control);
SendMessage(info.hwndItem, EM_SETCUEBANNER, 0, text);
}
else
{
SendMessage(control.Handle, EM_SETCUEBANNER, 0, text);
}
}
private static COMBOBOXINFO GetComboBoxInfo(Control control)
{
COMBOBOXINFO info = new COMBOBOXINFO();
//a combobox is made up of three controls, a button, a list and textbox;
//we want the textbox
info.cbSize = Marshal.SizeOf(info);
GetComboBoxInfo(control.Handle, ref info);
return info;
}
public static string GetCueText(Control control)
{
StringBuilder builder = new StringBuilder();
if (control is ComboBox)
{
COMBOBOXINFO info = new COMBOBOXINFO();
//a combobox is made up of two controls, a list and textbox;
//we want the textbox
info.cbSize = Marshal.SizeOf(info);
GetComboBoxInfo(control.Handle, ref info);
SendMessage(info.hwndItem, EM_GETCUEBANNER, 0, builder);
}
else
{
SendMessage(control.Handle, EM_GETCUEBANNER, 0, builder);
}
return builder.ToString();
}
}
Hay funcionalidad incorporada en el control de cuadro de texto - AutoCompleteMode y AutoCompleteSource . Puede valer la pena intentarlo antes de entrar en controles personalizados o de terceros.
Prueba el código de este enlace. Extiende la funcionalidad de winforms, ya que no es posible lograrlo de manera inmediata. El código fuente está disponible también. Tenga en cuenta que solo funciona en Win XP o superior.
http://www.aaronlerch.com/blog/2007/12/01/watermarked-edit-controls/
Deberá usar algún código de interoperabilidad P / Inovke para hacer esto. Busque la función SendMessage
API Win32 y el mensaje EM_SETCUEBANNER
.