Android玄铁剑之TextView之图文并茂

传送门 ☞ Android兵器谱 ☞ 转载请注明 ☞ http://blog.csdn.net/leverage_1229

玄铁剑
        此剑剑身长愈三尺,两边剑锋均为钝口,剑尖圆圆似是半球,通体深黑,却隐隐透出红光。剑以玄铁制成,共重八八六十四斤。

        本节我们学习如何利用Android平台“玄铁剑”TextView来显示表情图像和文字,下面给出该情景的案例:

一、案例技术要点

1.java.lang.reflect.Field:利用Reflect相关技术获取资源文件夹下表情图片ID。

2.android.text.Html.fromHtml(...):提供包含Html标签格式的文本内容。其中的第二个参数new ImageGetter() {...}:表示该字符串内容中可以包含图片资源。

3.android.text.method.LinkMovementMethod:提供超链接功能。TextView需要此功能时引入该类的实例即可。

4.drawable.getIntrinsicWidth():获取图片的实际宽度;drawable.getIntrinsicHeight():获取图片的实际高度。

二、案例代码陈列

AndroidManifest.xml

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.android.textview"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="15" />

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".TextViewMainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>
strings.xml
<resources>
    <string name="app_name">TextView显示表情图像和文字</string>
</resources>
main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >
    
    <TextView android:id="@+id/tv"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:background="#FFF" />
    
</LinearLayout>
TextViewMainActivity.java
package com.android.textview;

import java.lang.reflect.Field;

import android.app.Activity;
import android.graphics.Color;
import android.graphics.drawable.Drawable;
import android.os.Bundle;
import android.text.Html;
import android.text.Html.ImageGetter;
import android.text.method.LinkMovementMethod;
import android.widget.TextView;

/**
 * TextView案例二:显示表情图像和文字
 * @author lynnli1229
 */
public class TextViewMainActivity extends Activity {
    private TextView textView;
    
    public int getResourceId(String name) {
        try {
            // 根据资源ID的变量名获取Field对象
            Field field = R.drawable.class.getField(name);
            // 获取并返回资源ID的字段(静态变量)的值
            return Integer.parseInt(field.get(null).toString());
        } catch (Exception e) {
            e.printStackTrace();
        }
        return 0;
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
        textView = (TextView) findViewById(R.id.tv);
        textView.setTextColor(Color.BLACK);
        textView.setBackgroundColor(Color.WHITE);
        textView.setTextSize(20);
        String html = "图像1<img src='image1' />图像2<img src='image2' />图像3<img src='image3' /><p>";
        html += "图像4<a href='http://www.baidu.com'><img src='image4' /></a>图像5<img src='image5' />";
        
        CharSequence charSequence = Html.fromHtml(html, new ImageGetter() {
            @Override
            public Drawable getDrawable(String source) {
                // 获取系统资源信息
                Drawable drawable = getResources().getDrawable(getResourceId(source));
                //50%压缩处理第三个图片
                if(source.equals("image3")) {
                    drawable.setBounds(0, 0, drawable.getIntrinsicWidth()/2, drawable.getIntrinsicHeight()/2);
                }else {
                    drawable.setBounds(0, 0, drawable.getIntrinsicWidth(), drawable.getIntrinsicHeight());
                }
                return drawable;
            }
        }, null);
        textView.setText(charSequence);
        textView.setMovementMethod(LinkMovementMethod.getInstance());
        
    }

}

        友情提示:提供五张表情图片(QQ表情)存放于drawable-hdpi文件夹下。

三、案例效果展示

原文地址:https://www.cnblogs.com/innosight/p/3271195.html