精华内容
下载资源
问答
  • Android TextView 换行不对齐的问题
  • 下面小编就为大家分享一篇浅谈Android textview文字对齐换行的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
  • Android textview换行

    千次阅读 2019-04-02 19:55:18
    在某种情况下需要将TextView里面的文本进行换行,这时候只需要在将要换行的前面加上 \n 例如: 1.更新内容;\n2.更新内容啦;\n3.更新内容,赶紧查看;\n1.更新内容 在Android Studio上显示不出来效果,但是你运行...

    在某种情况下需要将TextView里面的文本进行换行,这时候只需要在将要换行的前面加上 \n

    例如:

    1.更新内容;\n2.更新内容啦;\n3.更新内容,赶紧查看;\n1.更新内容
    

    在Android Studio上显示不出来效果,但是你运行起来,跑真机上就可以了。


    关注「蛇崽网盘教程资源」公众号 ,在微信后台回复「领取资源」,获取IT资源200G干货大全。

    更多资源请访问:

    超详细图文搭建个人免费博客

    关注「蛇崽网盘教程资源」公众号 ,在微信后台回复「领取资源」,获取IT资源200G干货大全。

    在微信后台回复「130个小程序」,即可免费领取享有导入就能跑的微信小程序

    在这里插入图片描述

    展开全文
  • android textview换行

    千次阅读 2020-05-11 23:25:53
    android:scrollHorizontally="false" android:inputType="textMultiLine" ...在你的textview 要加上这三行 用的时候 tv.setText("aa\nbb"); tv.setTest(Html.fromHtml("xxx<br>xxx<br>"));
    android:scrollHorizontally="false"
     android:inputType="textMultiLine"
    android:singleLine="false"

    在你的textview 要加上这三行

    用的时候

    tv.setText("aa\nbb");

    tv.setTest(Html.fromHtml("xxx<br>xxx<br>"));

     

    展开全文
  • 解决TextView自动换行的排版混乱 允许设置SpannableString等特殊属性 至繁归于至简
  • MTextView,解决Android TextView提前换行的问题
  • android textview 文字排版 换行

    千次下载 热门讨论 2012-04-16 23:58:06
    android textview 文字排版 换行
  • Android TextView换行问题

    千次阅读 2014-04-23 16:26:11
    1) TextView在显示中文的时候 标点符号不能显示在一行的行首和行尾,如果一个标点符号刚好在一行的行尾,该标点符号就会连同前一个字符跳到下一行显示; 2)一个英文单词不能被显示在两行中( Te

    本文转载于:http://niufc.iteye.com/blog/1729792

    ndroid的TextView在显示文字的时候有个问题就是一行还没显示满就跳到下一行,原因是:

    1) TextView在显示中文的时候 标点符号不能显示在一行的行首和行尾,如果一个标点符号刚好在一行的行尾,该标点符号就会连同前一个字符跳到下一行显示;

    2)一个英文单词不能被显示在两行中( TextView在显示英文时,标点符号是可以放在行尾的,但英文单词也不能分开 );

    如果只是想让标点符号可以显示在行尾,有一个简单的方法就是在标点符号后加一个空格,则该标点符号就可以显示在行尾了;

    如果想要两端对齐的显示效果,有两种方法:

    1)修改Android源代码;将frameworks/base/core/java/android/text下的StaticLayout.java文件中的如下代码:

                          if (c == ' ' || c == '/t' ||
                                ((c == '.'  || c == ',' || c == ':' || c == ';') &&
                                 (j - 1 < here || !Character.isDigit(chs[j - 1 - start])) &&
                                 (j + 1 >= next || !Character.isDigit(chs[j + 1 - start]))) ||
                                ((c == '/' || c == '-') &&
                                 (j + 1 >= next || !Character.isDigit(chs[j + 1 - start]))) ||
                                (c >= FIRST_CJK && isIdeographic(c, true) &&
                                 j + 1 < next && isIdeographic(chs[j + 1 - start], false))) {
                                okwidth = w;
                                ok = j + 1;

                                if (fittop < oktop)
                                    oktop = fittop;
                                if (fitascent < okascent)
                                    okascent = fitascent;
                                if (fitdescent > okdescent)
                                    okdescent = fitdescent;
                                if (fitbottom > okbottom)
                                    okbottom = fitbottom;
                            }

    去掉就可以了。去掉后标点符号可以显示在行首和行尾,英文单词也可以被分开在两行中显示。

    但是我师傅说修改框架不美气,会影响其它应用程序,www.linuxidc.com 最好是能在应用层面解决问题。 所以就有了方法2;

    2)自定义View显示文本

    网上就有达人采用自定义View来解决这个问题,我做了实验并总结了一下:

    自定义View的步骤:  

    1)继承View类或其子类,例子继承了TextView类;

    2)写构造函数,通过XML获取属性(这一步中可以自定义属性,见例程);

    3)重写父类的某些函数,一般都是以on开头的函数,例子中重写了onDraw()和onMeasure()函数;

     

    =========================CYTextView.java=============================

    public class CYTextView extends TextView {
        public  static  int m_iTextHeight; //文本的高度
        public  static  int m_iTextWidth;//文本的宽度
        
        private Paint mPaint = null;
        private String string="";
        private float LineSpace = 0;//行间距
            
        public CYTextView(Context context, AttributeSet set) 
        {       
            super(context,set);  

            TypedArray typedArray = context.obtainStyledAttributes(set, R.styleable.CYTextView);

            int width = typedArray.getInt(R.styleable.
     CY 
    TextView_textwidth, 320);
            float textsize = typedArray.getDimension(R.styleable.
     CY 
    TextView_textSize, 24);
            int textcolor = typedArray.getColor(R.styleable.
     CY 
    TextView_textColor, -1442840576);
            float linespace = typedArray.getDimension(R.styleable.
     CY 
    TextView_lineSpacingExtra, 15);
            int typeface = typedArray.getColor(R.styleable.
     CY 
    TextView_typeface, 0);
            
            typedArray.recycle();
            
            //设置
     CY 
    TextView的宽度和行间距www.linuxidc.com
            m_iTextWidth=width;
            LineSpace=linespace;
            
            // 构建paint对象      
            mPaint = new Paint();
            mPaint.setAntiAlias(true);
            mPaint.setColor(textcolor);
            mPaint.setTextSize(textsize);
            switch(typeface){
            case 0:
                mPaint.setTypeface(Typeface.DEFAULT);
                break;
            case 1:
                mPaint.setTypeface(Typeface.SANS_SERIF);
                break;
            case 2:
                mPaint.setTypeface(Typeface.SERIF);
                break;
            case 3:
                mPaint.setTypeface(Typeface.MONOSPACE);
                break;
            default:
                mPaint.setTypeface(Typeface.DEFAULT);    
                break;
            }
            
        }
      
        @Override
        protected void onDraw(Canvas canvas) 
        {  
           super.onDraw(canvas);       
            
            char ch;
            int w = 0;
            int istart = 0;
            int m_iFontHeight;
            int m_iRealLine=0;
            int x=2;
            int y=30;
            
            Vector    m_String=new Vector();
            
            FontMetrics fm = mPaint.getFontMetrics();        
            m_iFontHeight = (int) Math.ceil(fm.descent - fm.top) + (int)LineSpace;//计算字体高度(字体高度+行间距)

            for (int i = 0; i < string.length(); i++)
            {
                ch = string.charAt(i);
                float[] widths = new float[1];
                String srt = String.valueOf(ch);
                mPaint.getTextWidths(srt, widths);

                if (ch == '/n'){
                    m_iRealLine++;
                    m_String.addElement(string.substring(istart, i));
                    istart = i + 1;
                    w = 0;
                }else{
                    w += (int) (Math.ceil(widths[0]));
                    if (w > m_iTextWidth){
                        m_iRealLine++;
                        m_String.addElement(string.substring(istart, i));
                        istart = i;
                        i--;
                        w = 0;
                    }else{
                        if (i == (string.length() - 1)){
                            m_iRealLine++;
                            m_String.addElement(string.substring(istart, string.length()));
                        }
                    }
                }
            }
            m_iTextHeight=m_iRealLine*m_iFontHeight+2;
            canvas.setViewport(m_iTextWidth, m_iTextWidth);
            for (int i = 0, j = 0; i < m_iRealLine; i++, j++)
            {
                canvas.drawText((String)(m_String.elementAt(i)), x,  y+m_iFontHeight * j, mPaint);
            }
        }  
       
        
        protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) 
        {          
            int measuredHeight = measureHeight(heightMeasureSpec);          
            int measuredWidth = measureWidth(widthMeasureSpec);           
            this.setMeasuredDimension(measuredWidth, measuredHeight);
            this.setLayoutParams(new LinearLayout.LayoutParams(measuredWidth,measuredHeight));
            super.onMeasure(widthMeasureSpec, heightMeasureSpec);
        }  
                     
        private int measureHeight(int measureSpec) 
        {  
            int specMode = MeasureSpec.getMode(measureSpec);          
            int specSize = MeasureSpec.getSize(measureSpec);                   
            // Default size if no limits are specified.  
            initHeight();
            int result = m_iTextHeight;          
            if (specMode == MeasureSpec.AT_MOST){         
                // Calculate the ideal size of your          
                // control within this maximum size.          
                // If your control fills the available           
                // space return the outer bound.          
                result = specSize;           
            }else if (specMode == MeasureSpec.EXACTLY){           
                // If your control can fit within these bounds return that value.            
                result = specSize;           
            }           
            return result;            
        }  
        
        private void initHeight()
        {
            //设置
     CY 
    TextView的初始高度为0
            m_iTextHeight=0;
            
            //大概计算
     CY 
    TextView所需高度
            FontMetrics fm = mPaint.getFontMetrics();        
            int m_iFontHeight = (int) Math.ceil(fm.descent - fm.top) + (int)LineSpace;
            int line=0;
            int istart=0;
            
            int w=0;
            for (int i = 0; i < string.length(); i++)
            {
                char ch = string.charAt(i);
                float[] widths = new float[1];
                String srt = String.valueOf(ch);
                mPaint.getTextWidths(srt, widths);

                if (ch == '/n'){
                    line++;
                    istart = i + 1;
                    w = 0;
                }else{
                    w += (int) (Math.ceil(widths[0]));
                    if (w > m_iTextWidth){
                        line++;
                        istart = i;
                        i--;
                        w = 0;
                    }else{
                        if (i == (string.length() - 1)){
                            line++;
                        }
                    }
                }
            }
            m_iTextHeight=(line)*m_iFontHeight+2;
        }
                     
        private int measureWidth(int measureSpec) 
        {  
            int specMode = MeasureSpec.getMode(measureSpec);           
            int specSize = MeasureSpec.getSize(measureSpec);             
              
            // Default size if no limits are specified.          
            int result = 500;          
            if (specMode == MeasureSpec.AT_MOST){          
                // Calculate the ideal size of your control           
                // within this maximum size.         
                // If your control fills the available space         
                // return the outer bound.         
                result = specSize;          
            }else if (specMode == MeasureSpec.EXACTLY){           
                // If your control can fit within these bounds return that value.           
                result = specSize;            
            }           
            return result;          
        }
        
        public void SetText(String text)(注:此函数目前只有在UI线程中调用才可以把文本画出来,在其它线程中

                                                            无法画文本,找了好久找不到原因,求高手解答) 
        {
            string = text;
           // requestLayout();
           // invalidate();
        }   
    }

    该文件是自定义的属性,放在工程的res/values下

    <resources>
        <attr name="textwidth" format="integer"/>
        <attr name="typeface">
            <enum name="normal" value="0"/>
            <enum name="sans" value="1"/>
            <enum name="serif" value="2"/>
            <enum name="monospace" value="3"/>
        </attr>

        <declare-styleable name="CYTextView">    
            <attr name="textwidth" />        
            <attr name="textSize" format="dimension"/>
            <attr name="textColor" format="reference|color"/>
            <attr name="lineSpacingExtra" format="dimension"/>
            <attr name="typeface" />
            </declare-styleable>
    </resources>

     

    =======================main.xml==========================

    <?xml version="1.0" encoding="utf-8"?>
    <ScrollView
            xmlns:Android="http://schemas.android.com/apk/res/android"
            Android:layout_width="320px"
            Android:layout_height="320px"
            Android:background="#ffffffff"
            >
      <LinearLayout 
            xmlns:Android="http://schemas.android.com/apk/res/android"
            Android:orientation="vertical"
            Android:layout_width="fill_parent"
            Android:layout_height="fill_parent">
        <com.cy.CYTextView.CYTextView 
            xmlns:cy="http://schemas.Android.com/apk/res/
     
    com.cy.CYTextView "
            Android:id="@+id/mv"
            Android:layout_height="wrap_content"
            Android:layout_width="wrap_content" 
            
    cy 
    :textwidth="320"        
            
    cy 
    :textSize="24sp"
            
    cy 
    :textColor="#aa000000"
            
    cy 
    :lineSpacingExtra="15sp"
            
    cy 
    :typeface="serif">
        </com.
     cy 
    .CYTextView.CYTextView>    
      </LinearLayout>
    </ScrollView>
    蓝色代码即为自定义View,其中以cy命名空间开头的属性是自定义属性;

     

    =======================Main.java=============================

     

    public class Main extends Activity {
        CYTextView mCYTextView;
        String text = "Android提供了精巧和有力的组件化模型构建用户的UI部分。主要是基于布局类:View和        ViewGroup。在此基础上,android平台提供了大量的预制的View和xxxViewGroup子 类,即布局(layout)和窗口小部件(widget)。可以用它们构建自己的UI。";
        
        /** Called when the activity is first created. */
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            this.setContentView(R.layout.main);
            
            mCYTextView = (CYTextView)findViewById(R.id.mv);
            mCYTextView.SetText(text);
        }

    }

     

    运行结果如下:


    展开全文
  • android 逐行逐字显示的textview 播放通知的字幕 逐字逐行显示。可以控制显示的次数。
  • image.png我们都知道在Android中所有的控件都是矩形的,所以想通过单个Textview实现评论内容换行,并且与前段对齐市无法实现的,那么我们换个思路如果我们能够知道评论内容第一行最多能显示几个字符,那么剩下的就...

    最近开发遇到一个下面这种布局结构,关系到Textview的换行,并且第二行与前端图片对齐,后段追加时间的样式。

    8b2cbed9938d

    image.png

    我们都知道在Android中所有的控件都是矩形的,所以想通过单个Textview实现评论内容换行,并且与前段对齐市无法实现的,那么我们换个思路如果我们能够知道评论内容第一行最多能显示几个字符,那么剩下的就可以通过将内容拆分成两个Textview来实现,而关于后面追加的时间样式可以SpannableStringBuilder对第二个Textview进行修饰。

    首先我们来看看怎么获取第一行最多显示多少字符。

    xml布局

    android:id="@+id/v_text"

    android:layout_width="100dp"

    android:maxLines="1"

    android:text="dsadsadsasfreqrwqewqewqewqewqewq"

    android:layout_height="wrap_content"/>

    这里我们限制了宽度和最大行数,内容必然会被截断。

    kotlin

    v_text.viewTreeObserver.addOnGlobalLayoutListener(object :

    ViewTreeObserver.OnGlobalLayoutListener {

    override fun onGlobalLayout() {

    v_text.viewTreeObserver.removeOnGlobalLayoutListener(this)

    val layout = v_text.layout

    val lineEnd = layout.getLineEnd(0)

    }

    })

    layout.getLineEnd(0)返回的就是第一行最后一个字符的位置。

    思路有了,那么我们就 使用组合自定义控件方式来实现,以便复用:

    布局部分:

    android:layout_width="match_parent"

    android:layout_height="wrap_content">

    android:id="@+id/v_hot_text"

    android:layout_width="wrap_content"

    android:layout_height="wrap_content"

    android:layout_marginLeft="13dp"

    android:layout_marginTop="3dp"

    android:layout_marginRight="7dp"

    android:background="@color/colorPrimary"

    android:drawablePadding="2dp"

    android:gravity="center_vertical"

    android:paddingLeft="3dp"

    android:paddingRight="3dp"

    android:text="热评"

    android:textColor="#ff333333"

    android:textSize="11sp"

    android:textStyle="bold" />

    android:id="@+id/v_hot_icon"

    android:layout_width="wrap_content"

    android:layout_height="wrap_content"

    android:src="@mipmap/ic_icon3" />

    android:id="@+id/v_content_line1"

    android:maxLines="1"

    android:layout_width="match_parent"

    android:layout_height="wrap_content"

    android:layout_toRightOf="@id/v_hot_text" />

    android:id="@+id/v_content_line2"

    android:layout_marginTop="5dp"

    android:layout_width="match_parent"

    android:layout_height="wrap_content"

    android:layout_below="@id/v_content_line1" />

    kotlin部分

    package com.lucas.test

    import android.content.Context

    import android.graphics.Color

    import android.text.Spannable

    import android.text.SpannableStringBuilder

    import android.text.style.AbsoluteSizeSpan

    import android.text.style.ForegroundColorSpan

    import android.util.AttributeSet

    import android.view.LayoutInflater

    import android.view.View

    import android.view.ViewGroup

    import android.widget.FrameLayout

    import android.widget.TextView

    /**

    * @package CommentChildView.kt

    * @author luan

    * @date 2019-11-06

    * @des 评论内容区

    */

    class CommentChildView : FrameLayout {

    constructor(context: Context) : super(context) {

    initView(context)

    }

    constructor(context: Context, attrs: AttributeSet?) : super(context, attrs) {

    initView(context)

    }

    constructor(context: Context, attrs: AttributeSet?, defStyleAttr: Int) : super(

    context,

    attrs,

    defStyleAttr

    ) {

    initView(context)

    }

    var rootView: ViewGroup? = null

    var contentStr: String = ""

    fun initView(context: Context) {

    rootView = LayoutInflater.from(context).inflate(

    R.layout.view_comment_child,

    null,

    false

    ) as ViewGroup

    addView(rootView)

    }

    fun setContent(content: String) {

    contentStr = content

    rootView?.apply {

    val line1 = findViewById(R.id.v_content_line1)

    line1.text = content

    //获取剩余未显示的字符串

    val lineEnd = line1.layout.getLineEnd(0)

    if (content.length == lineEnd) {//第一行已显示完,无需使用第二行显示

    } else {//启用第二行显示剩余字符

    val substring = content.substring(lineEnd, content.length)

    findViewById(R.id.v_content_line2).text = substring

    }

    }

    }

    fun isHot(isHot: Boolean) {

    rootView?.apply {

    if (isHot) {

    findViewById(R.id.v_hot_icon).visibility = View.VISIBLE

    findViewById(R.id.v_hot_text).visibility = View.VISIBLE

    } else {

    findViewById(R.id.v_hot_icon).visibility = View.GONE

    findViewById(R.id.v_hot_text).visibility = View.GONE

    }

    }

    }

    //追加时间样式--调用该方法前需先调用setContent,否则追加时间位置会出错

    fun setTime(time: String) {

    rootView?.apply {

    val line1 = findViewById(R.id.v_content_line1)

    val line2 = findViewById(R.id.v_content_line2)

    //判断追加第几行

    if (line2.text.toString().isEmpty()) {//追加第一行

    line1.text = "${line1.text} ${time}"

    //如果追加后超出一行,则放弃,改为追加到二行

    if (isSingleLine(line1)) {

    line1.text = contentStr

    initTimeStyle(line2, time)

    }else{

    line1.text = contentStr

    initTimeStyle(line1, time)

    }

    } else {//追加第二行

    line1.text = contentStr

    initTimeStyle(line2, time)

    }

    }

    }

    private fun initTimeStyle(line2: TextView, time: String) {

    line2.text = "${line2.text} $time"

    //修改时间样式

    val line2Str = line2.text

    val timeIndex = line2Str.indexOf(time)

    val builder = SpannableStringBuilder(line2Str)

    builder.setSpan(

    ForegroundColorSpan(Color.parseColor("#999999")),

    timeIndex,

    timeIndex + time.length,

    Spannable.SPAN_EXCLUSIVE_EXCLUSIVE

    )

    builder.setSpan(

    AbsoluteSizeSpan(11, true),

    timeIndex,

    timeIndex + time.length,

    Spannable.SPAN_EXCLUSIVE_EXCLUSIVE

    )

    line2.text = builder

    }

    //判断textview是否超出一行

    private fun isSingleLine(textView: TextView): Boolean {

    val lineEnd = textView.layout.getLineEnd(0)

    return textView.text.length > lineEnd

    }

    }

    具体运行效果:

    8b2cbed9938d

    image.png

    其中有点需要注意的是,在Textview没有绘制完成前textview.getLayout方法返回的是空的,使用时需要在合适的时机使用例如:

    xmlns:app="http://schemas.android.com/apk/res-auto"

    xmlns:tools="http://schemas.android.com/tools"

    android:layout_width="match_parent"

    android:layout_height="match_parent"

    tools:context=".MainActivity">

    android:id="@+id/v_comment"

    android:layout_width="200dp"

    android:layout_height="wrap_content"/>

    class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {

    super.onCreate(savedInstanceState)

    setContentView(R.layout.activity_main)

    v_comment.viewTreeObserver.addOnGlobalLayoutListener(object :ViewTreeObserver.OnGlobalLayoutListener{

    override fun onGlobalLayout() {

    v_comment.viewTreeObserver.removeOnGlobalLayoutListener(this)

    v_comment.setContent("法规和冯绍峰dasdadasdauguyguihiuh")

    v_comment.isHot(true)

    v_comment.setTime("12-11")

    }

    })

    }

    }

    展开全文
  • textView如果想要强制换行的话,必须先把TextView显示方式修改为多行(android:singleLine="false"),然后才能换行。方法一般用两种:1、在字符串里加入“\n”,如"abc\nrc";2、把TextView设置为固定宽度,然后让系统...
  • import android.content.Context;import android.text.Layout;import android.text.StaticLayout;import android.text.TextPaint;import android.util.AttributeSet;import android.view.View;i...
  • 解决TextView异常换行

    2016-05-04 17:55:35
    TextView显示的时候,会出现一个问题就是显示的文字中有括号、数字、或者英文的话他会立刻就换行,因为括号、数字等是半角,而汉字是全角,所以我们需要把半角转换为全角,使它们与汉字同占两个字节,现在已经解决...
  • Android TextView停止换行

    2021-05-26 15:35:17
    当我在G2上运行我的应用程序时,我的所有textview都不会换行.(不管视图有多大.)如果我在模拟器上运行,它们会自动换行.部署到我的G2时,其他所有应用程序似乎都没有这个问题.我关闭了设备的电源,重新创建了布局,等等.这...
  • 网上的加以修改import android.content.Context; import android.text.Layout; import android.util.AttributeSet; import android.widget....import android.widget.TextView; /** * Created by Administrato...
  • android textview 自动换行 整齐排版

    千次阅读 2019-05-08 10:03:38
    textview显示长文字时会进行自动折行,如果遇到一些特殊情况,自动折行会杯具成这个样子: 上述特殊情况包括: 1)全角/半角符号混排(一般是数字、字母、汉字混排) 2)全角/半角标点符号出现在行首时,该标点...
  • 本类实现了文字的竖直排版显示(中国古时的行文形式),虽然仍有许多特效及功能仍未实现,但基本的使用已经能满足。版权:尽管放心用吧,可以自行随意改进转载和使用,转载时请保留这段文字即可另特别感谢 老僧xp ...
  • TextView 换行对齐自定义

    千次阅读 2017-04-22 11:48:34
    package com.imay.live.view... import android.content.Context; import android.graphics.Canvas; import android.graphics.Paint; import android.util.AttributeSet;...import android.widget.TextView; /** * 左对
  • 两个功能 解决中英文结合导致提前换行bug。 textview动态变化行(显示更多),点击更多弹出全部textview再点击隐藏。
  • 关于TextView异常换行,参差不齐问题分析:每行的开头的第一个字符如果是字母,数字,标点符号以及特殊字符 可能是由于都是半角字符,所以需要转化成全角字符解决方法是:public String transport(String inputStr){...
  • 1、半角字符与全角字符混乱所致:这种情况一般就是汉字与数字、英文字母混用解决方法一:将textview中的字符全角化。即将所有的数字、字母及标点全部转为全角字符,使它们与汉字同占两个字节,这样就可以避免由于...
  • 判断Android Textview是否换行 1.先设置ellipsize=“end” 2.通过addOnGlobalLayoutListene方法判断是否触发ellipsize="end"来判断是否换行 private void TvOverFlowed(final TextView textView,final View img) { ...
  • 解决TextView的排版问题-自动换行

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 8,851
精华内容 3,540
关键字:

安卓textview换行