欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#中TextBox的橫線樣式及占位提示詳解

 更新時(shí)間:2022年11月14日 11:19:14   作者:Csharp小記  
橫線樣式就是將TextBox以一條底橫線的形式展示在頁面,占位提示就是Web的Placeholder屬性,即在輸入框沒有內(nèi)容的時(shí)候進(jìn)行一個(gè)輸入提示。本文主要介紹了C#中TextBox的這兩個(gè)的實(shí)現(xiàn),需要的可以參考一下

文章描述

可能我標(biāo)題描述不太準(zhǔn)確,所以還是要稍微解釋下:橫線樣式就是將TextBox以一條底橫線的形式展示在頁面,占位提示就是Web的Placeholder屬性,即在輸入框沒有內(nèi)容的時(shí)候進(jìn)行一個(gè)輸入提示。其實(shí)以上兩個(gè)功能,無論是在Web還是WPF中,實(shí)現(xiàn)起來都比較簡單,Winform反而比較困難。但是值得慶幸的是,在.Net Core Winform中,Placeholder已經(jīng)內(nèi)置進(jìn)去了,可以直接使用。

為了方便使用,以下代碼中還是使用自定義控件來實(shí)現(xiàn)這兩個(gè)功能,只要設(shè)置屬性即可看到效果。

開發(fā)環(huán)境

.NET Framework版本:4.5

開發(fā)工具

 Visual Studio 2013

實(shí)現(xiàn)代碼

public partial class TextBoxP : TextBox
    {
        private const int EM_SETCUEBANNER = 0x1501;
        [DllImport("user32.dll", CharSet = CharSet.Auto)]
        private static extern Int32 SendMessage(IntPtr hWnd, int msg, int wParam, [MarshalAs(UnmanagedType.LPWStr)]string lParam);

        Panel panel = new Panel();

        public TextBoxP()
        {
            InitializeComponent();
            this.BorderStyle = BorderStyle.FixedSingle;
            this.Font = new Font("宋體", 12f);
        }

        private string _Placeholder;
        [Browsable(true)]
        [Description("設(shè)置提示信息")]
        public string Placeholder
        {
            get
            {
                return _Placeholder;
            }
            set
            {
                _Placeholder = value;
                SendMessage(Handle, EM_SETCUEBANNER, 0, _Placeholder);
            }
        }

        private bool _IsLineStyle;
        [Browsable(true)]
        [Description("設(shè)置以橫線樣式顯示")]
        public bool IsLineStyle
        {
            get { return _IsLineStyle; }
            set
            {
                _IsLineStyle = value;
                SetLineStyle();
            }
        }

        private void SetLineStyle()
        {
            if (_IsLineStyle && !this.Controls.Contains(panel))
            {
                this.BorderStyle = BorderStyle.None;

                this.SuspendLayout();
                panel.Height = 1;
                panel.Width = this.Width;
                panel.BorderStyle = BorderStyle.FixedSingle;
                panel.Location = new Point(0, this.Height - 1);
                this.Controls.Add(panel);
                this.ResumeLayout();
                this.PerformLayout();

                this.SizeChanged += TextBoxP_SizeChanged;
                this.LocationChanged += TextBoxP_LocationChanged;
            }
            else if (!_IsLineStyle)
            {
                if (this.Controls.Contains(panel))
                {
                    this.Controls.Remove(panel);
                }
                this.BorderStyle = BorderStyle.FixedSingle;
                this.SizeChanged -= TextBoxP_SizeChanged;
                this.LocationChanged -= TextBoxP_LocationChanged;
            }

            if (!string.IsNullOrWhiteSpace(_Placeholder))
            {
                SendMessage(Handle, EM_SETCUEBANNER, 0, _Placeholder);
            }
        }

        void TextBoxP_SizeChanged(object sender, EventArgs e)
        {
            panel.Width = this.Width;
        }
        void TextBoxP_LocationChanged(object sender, EventArgs e)
        {
            panel.Location = new Point(0, this.Height - 1);
        }

    }
 private void button1_Click(object sender, EventArgs e)
        {
            textBoxP1.IsLineStyle = !textBoxP1.IsLineStyle;
            textBoxP1.BackColor = textBoxP1.IsLineStyle ? SystemColors.Control : Color.White;

            textBoxP2.IsLineStyle = !textBoxP2.IsLineStyle;
            textBoxP2.BackColor = textBoxP2.IsLineStyle ? SystemColors.Control : Color.White;
        }

實(shí)現(xiàn)效果

代碼解析:Placeholder功能是使用Win APi做的,不得不說,這個(gè)方式的確是簡單。一開始是想著可以用字體顏色以及對應(yīng)的事件做到,但是效果不太完美,因?yàn)橛眠@種方式說到底還是對Text屬性的操作,最后獲取的時(shí)候還是會(huì)有問題,即便經(jīng)過判斷過濾之后,仍然感覺不太好用,最重要的是:麻煩!

然后就是橫線樣式顯示,這里是使用增加一個(gè)Panel控件來實(shí)現(xiàn),其實(shí)我一直覺得處理自定義控件的話,將樣式處理放在Paint事件中處理會(huì)比較完美,但是TextBox的Paint事件,有點(diǎn)難用。。。所以還是感覺這種方式簡單、有效!

到此這篇關(guān)于C#中TextBox的橫線樣式及占位提示詳解的文章就介紹到這了,更多相關(guān)C# TextBox內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C#中的Lazy如何使用詳解

    C#中的Lazy如何使用詳解

    這篇文章主要給大家介紹了C#中Lazy如何使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • C#的循環(huán)語句集錦及案例詳解

    C#的循環(huán)語句集錦及案例詳解

    這篇文章主要介紹了C#中的基本循環(huán):while循環(huán)、for循環(huán)和foreach循環(huán),大家都知道循環(huán)結(jié)構(gòu)可以簡化程序編碼,更好地實(shí)現(xiàn)理想的效果,并結(jié)合案例給大家講解,需要的朋友可以參考下
    2015-07-07
  • C#?Winform消息通知系統(tǒng)托盤氣泡提示框ToolTip控件

    C#?Winform消息通知系統(tǒng)托盤氣泡提示框ToolTip控件

    這篇文章主要為大家介紹了C#或Winform中的消息通知之系統(tǒng)托盤的氣泡提示框窗口(系統(tǒng)toast通知)、ToolTip控件和ToolTipText屬性詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • C#/VB.NET?實(shí)現(xiàn)彩色PDF轉(zhuǎn)為灰度PDF

    C#/VB.NET?實(shí)現(xiàn)彩色PDF轉(zhuǎn)為灰度PDF

    本文以C#代碼為例介紹如何實(shí)現(xiàn)將彩色PDF文件轉(zhuǎn)為灰度(黑白)的PDF文件,即將PDF文檔里面的彩色圖片或者文字等通過調(diào)用方法轉(zhuǎn)為文檔頁面為灰色調(diào)、無彩色效果的文檔。快來跟隨小編一起學(xué)習(xí)吧
    2021-11-11
  • 大白話講解C# 中的委托

    大白話講解C# 中的委托

    這篇文章主要介紹了C# 中的委托的相關(guān)資料,幫助初學(xué)者更好的理解和使用c#,感興趣的朋友可以了解下
    2020-11-11
  • 詳解.NET 4.0中的泛型協(xié)變(covariant)和反變(contravariant)

    詳解.NET 4.0中的泛型協(xié)變(covariant)和反變(contravariant)

    這篇文章主要介紹了詳解.NET 4.0中的泛型協(xié)變(covariant)和反變(contravariant),本文講解了協(xié)變和反變的背景知識(shí)、.NET 4.0引入的泛型協(xié)變、反變性、協(xié)變和反變的相互作用等內(nèi)容,需要的朋友可以參考下
    2015-06-06
  • 基于C#實(shí)現(xiàn)簡易的鍵盤記錄器

    基于C#實(shí)現(xiàn)簡易的鍵盤記錄器

    本文將利用C#語言和HOOK技術(shù)來做一個(gè)鍵盤記錄器,看看一天下來,我們點(diǎn)擊了多少次鍵盤,哪些鍵的使用頻率最高,感興趣的小伙伴可以嘗試一下
    2022-08-08
  • C#導(dǎo)入導(dǎo)出Excel數(shù)據(jù)的兩種方法

    C#導(dǎo)入導(dǎo)出Excel數(shù)據(jù)的兩種方法

    這篇文章主要為大家詳細(xì)介紹了C#導(dǎo)入導(dǎo)出Excel數(shù)據(jù)的兩種方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • C#實(shí)現(xiàn)圖片切割的方法

    C#實(shí)現(xiàn)圖片切割的方法

    這篇文章主要介紹了C#實(shí)現(xiàn)圖片切割的方法,涉及C#使用Graphics實(shí)現(xiàn)圖片屬性的相關(guān)設(shè)置、保存等操作技巧,需要的朋友可以參考下
    2017-06-06
  • C#對稱加密與非對稱加密實(shí)例

    C#對稱加密與非對稱加密實(shí)例

    這篇文章主要介紹了C#對稱加密與非對稱加密實(shí)例,詳細(xì)分析了對稱加密與非對稱加密的原理與具體實(shí)現(xiàn)方法,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下
    2014-10-10

最新評論