<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin" > <!-- android 简单的两步实现Play上的文本伸缩功能 -->
<!-- http://www.cnblogs.com/TerryBlog/archive/2013/03/12/2956165.html -->
<FrameLayout
android:id="@+id/expandable_container"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:layout_marginBottom="@dimen/linear_margin_bigger" > <TextView
android:id="@+id/expandable_text"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:clickable="true"
android:ellipsize="end"
android:text="@string/loremipsum" />
</FrameLayout> <!-- my method -->
<FrameLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content" > <TextView
android:id="@+id/myexpandable_text"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:maxLines="3"
android:clickable="true"
android:ellipsize="end"
android:text="@string/loremipsum" />
</FrameLayout> </LinearLayout>
package com.lxh.textview;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.view.ViewGroup.LayoutParams;
import android.widget.TextView; import com.example.com.lxh.pro1.R; /**
* android 简单的两步实现Play上的文本伸缩功能
* http://www.cnblogs.com/TerryBlog/archive/2013/03/12/2956165.html
* @author lxh
*/
public class ExpandableTV extends Activity {
// -------------------------- Terry's method --------------------------
private boolean isExpanded = false, myIsExpanded = false;
private int lastHeight = 0;
private ViewGroup expandableContainer;
private TextView textView, myTextView; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_expandable_tv);
expandableContainer = (ViewGroup) findViewById(R.id.expandable_container);
textView = (TextView) findViewById(R.id.expandable_text);
textView.setOnClickListener(terryClickListener);
myTextView = (TextView) findViewById(R.id.myexpandable_text);
myTextView.setOnClickListener(myClickListener);
} private OnClickListener terryClickListener = new OnClickListener() {
@Override
public void onClick(View v) {
if (isExpanded) {
LayoutParams params = (LayoutParams) expandableContainer.getLayoutParams();
params.height = lastHeight;
expandableContainer.setLayoutParams(params);
expandableContainer.invalidate(); //调用OnDraw方法
} else {
lastHeight = expandableContainer.getHeight();
LayoutParams params = (LayoutParams) expandableContainer.getLayoutParams();
params.height = ViewGroup.LayoutParams.WRAP_CONTENT;
expandableContainer.setLayoutParams(params);
expandableContainer.invalidate(); //调用OnDraw方法
}
isExpanded = !isExpanded;
}
};
//Terry总结:此方法缺陷,当给出最大高度不合适时,字会显示一半高度 // -------------------------- my method --------------------------
private OnClickListener myClickListener = new OnClickListener() {
@Override
public void onClick(View v) {
if (myIsExpanded) {
myTextView.setMaxLines(3);
expandableContainer.invalidate(); //调用OnDraw方法
} else {
myTextView.setMaxLines(Integer.MAX_VALUE);
expandableContainer.invalidate(); //调用OnDraw方法
}
myIsExpanded = !myIsExpanded;
}
};
//Me总结:此方法不存在Terry的问题
}

可收缩的TextView的更多相关文章

  1. Android TableLayout中的使用说明

    TableLayout特点: 1)TableLayout和我们平时在网页上见到的Table有所不同,TableLayout没有边框的 2)它是由多个TableRow对象组成,每个TableRow可以有 ...

  2. 【Android】7.4TableLayout(表格布局)

    分类:C#.Android.VS2015: 创建日期:2016-02-11 一.简介 TableLayout也是用行和列划分单元格,但不会显示Row.Column以及Cell的边框线,其子元素有许多T ...

  3. (转)可收缩、扩展的TextView

    在一些应用中,比如腾讯的应用市场APP应用宝,关于某款应用的介绍文字,如果介绍文字过长,那么不是全部展现出来,而是显示三四行的开始部分(摘要),预知全部的内容,用户点击展开按钮即可查阅全部内容.这样的 ...

  4. 可伸缩的textview。

    在一些应用中,比如腾讯的应用市场APP应用宝,关于某款应用的介绍文字,如果介绍文字过长,那么不是全部展现出来,而是显示三四行的开始部分(摘要),预知全部的内容,用户点击展开按钮即可查阅全部内容. 这样 ...

  5. 关于textview显示特殊符号居中的问题

    话说这是2017年的第一篇博客,也是一篇技术博客.先从简单的一篇解决问题开始吧,千里之行,始于足下! ------------------------------------------------- ...

  6. 奇葩问题-TextView无法获取值

    问题场景 前几天写一个界面的时候,遇到一个非常奇葩的问题.app第一次安装的时候,这里针对用户第一次安装的时候,后来是不会出现这个问题了.我明明是对某个界面的一个textview赋值了,而且服务端也返 ...

  7. 动态给textView加图片

    Drawable img = layout.getResources().getDrawable(R.drawable.icon); // 调用setCompoundDrawables时,必须调用Dr ...

  8. TextView使用大全

    最近打算写一个系列的android初级开发教程,预计40篇以上的文章,结合我实际工作中的经验,写一些工作中经常用到的技术,让初学者可以少走弯路,写一个系列的话,大家学习起来也有头有尾. 今天就从我们每 ...

  9. TextField和TextView的限制输入长度

    TextField的限制代理方法 只需要在这个代理方法里面code这样的代码就可以了 16 是长度可以自己设置 - (BOOL)textField:(UITextField *)textField s ...

随机推荐

  1. 网页中输出漂亮格式的Php数组神器

    写网页的时候经常需要在页面中打印数组,但格式特别难看,看看一个html神器吧<pre>标签,能非常标准的显示数组格式 使用的时候只需要这样打印你的数组就OK了,太好用了,神器! 只需要两句 ...

  2. utf8汉字编码16进制对照(转载)

    utf8汉字编码16进制对照 GB Unicode UTF-8 Chinese CharacterCode code# Code (coded in UTF-8)D2BB 4E00 E4 B8 80 ...

  3. Python 爬取外文期刊论文信息(机械 仪表工业)

    NSTL国家科技图书文献中心    2017  机械 仪表工业  所有期刊论文信息 代码比较随意,不要介意 第一步,爬取所有期刊链接 #coding=utf-8 import time from se ...

  4. 分析apache日志,统计ip访问频次命令

    统计访问频次最高的10个ip: cat /var/log/httpd/access_log |awk '{print $1}'|sort|uniq -c|sort -nr|head -10 统计恶意i ...

  5. nginx 相关命令 nginx -s reload/stop/quit

    nginx 相关命令 学习了:https://www.cnblogs.com/zoro-zero/p/6590503.html start nginx  或者在linux上面直接 nginx ngin ...

  6. 云计算之路-试用Azure:上不了高速的跑车,无法跨Cloud Service的DNS服务器

    从阿里云的踩坑大师,到Azure的抹黑大师,我们似乎成了云计算负面用户的典型,可是我们还是忍不住想表达自己真实的使用感受.如果有错误的地方,欢迎大家批评! 在Azure上建好虚拟网(Vitual Ne ...

  7. 数据採集器服务——Socket(今天才发现AES加解密代码跟贴的时候不一样,貌似乱码,不知什么情况)

    近期刚做的一个项目.关于 Socket TCP 通信. 需求方提供了一个 ARM 机器,及数据採集器,须要我做一个服务端与数据採集器进行交互. 目的: 数据採集器:定时将读取到的数据发送到服务端. 服 ...

  8. C++中返回对象的情形及RVO

    http://www.cnblogs.com/xkfz007/archive/2012/07/21/2602110.html 之前有文章介绍过临时对象和返回值优化RVO方面的问题.见此处. 在C++中 ...

  9. C#下载apk文件

    string fileName = "name.apk";//客户端保存的文件名         string filePath = Server.MapPath("ap ...

  10. CSS-常用媒体查询

    width:视口宽度.height:视口高度.device-width:渲染表面的宽度(对我们来说,就是设备屏幕的宽度).device-height:渲染表面的高度(对我们来说,就是设备屏幕的高度). ...