zoukankan      html  css  js  c++  java
  • 【转】winform程序textbox滚动条保持在最下面 内容不闪烁

      在开发winform程序时,会用到textbox控件来显示信息,当把textbox的Multiline属性改为Ture时(即多行显示状态),ScrollBars属性改为Vertical(内容过多时,显示竖状滚动条),显示内容过多时就会出现竖状滚动条。

      默认情况下,当textbox内容改变时,winform会自动把textbox的滚动条定位到textbox的最上面。但这显然不是我们想要的结果,比如我们在开发一个聊天程序时,当发送了一条消息后,却还要把滚动条拖到最下面才能看到,这就让人火大了。

      所以得想个办法让textbox的内容更新时,滚动条保持下最下面,让最新追加到textbox中的消息显示出来。一般用到的方法是在textbox的TextChanged事件中写如下代码:

      

    private void txt_content_TextChanged(object sender, EventArgs e)
    {
        this.txt_content.SelectionStart = this.txt_content.Text.Length;
        this.txt_content.SelectionLength = 0;
        this.txt_content.ScrollToCaret();
    }
    View Code

      问题解决了,一切看似很好,后来你却发现,问题是解决了,但每次textbox追加内容时,都会“闪”那么一下。这个时候,如果你写的程序要频繁的更新textbox的内容,如显示一个程序的安装过程,灾难降临了。你就看吧,那个框框会“闪”的你眼晕!

      把上面那部分代码从你的程序中删掉吧!在更新textbox内容的地方用下的代码试试:

      

    //向textbox追加内容txt_content.AppendText(str);

      运行你的程序吧!

  • 相关阅读:
    ue4 材质表达式分类
    UE4材质特别属生记录
    tangent space与object space
    better-scroll插件 api
    better-scroll 与 Vue 结合
    git 简介
    vue 插件
    前端小程序——js+canvas 给图片添加水印
    使用Node.js给图片加水印的方法
    Vue框架 周期
  • 原文地址:https://www.cnblogs.com/SALIN/p/3333507.html
Copyright © 2011-2022 走看看