Android实现文字和图片混排(文字环绕图片)效果

本文实例讲述了Android实现文字和图片混排(文字环绕图片)效果。分享给大家供大家参考,具体如下:

在平时我们做项目中,或许有要对一张图片或者某一个东西进行文字和图片说明,这时候要求排版美观,所以会出现文字和图片混排的情况,如图:

这种情况就是上下两个文字说明是连续在一起的,这就要求我们计算上面的文字说明怎么和下面的文字说明连贯结合在一起呢,这就要求我们进行计算了,下面给出代码,代码中也有详细的注释,原理也很简单。

因为算是比较简单,直接就在activity中去计算了:

package com.example.test; import android.app.Activity; import android.graphics.Paint; import android.os.Bundle; import android.view.ViewTreeObserver; import android.widget.ImageView; import android.widget.TextView; public class MainActivity extends Activity { boolean imageMeasured = false; TextView tv_right; TextView tv_bottom; static final String text = "叶凡:小说主角,与众老同学在泰山聚会时一同被九龙拉棺带离地球," + "进入北斗星域,得知自己是荒古圣叶凡 叶凡体。历险禁地,习得源术,斗圣地世家,战太古生物," + "重组天庭,叶凡辗转四方得到许多际遇和挑战,功力激增,眼界也渐渐开阔。一个浩大的仙侠世界," + "就以他的视角在读者面前展开。姬紫月:姬家小姐,出场年龄十七岁。被叶凡劫持一同经历青铜古殿历险," + "依靠碎裂的神光遁符解除禁制,反过来挟持叶凡一同进入太玄派寻找秘术。" + "在叶凡逃离太玄后姬紫月在孔雀王之乱中被华云飞追杀,又与叶凡[2]相遇,被叶凡护送回姬家" + ",渐渐对叶凡产生微妙感情。后成为叶凡的妻子,千载后于飞仙星成仙,在叶凡也进入仙路后再见庞博:" + "叶凡大学时最好的朋友,壮硕魁伟,直率义气。到达北斗星域后因服用了圣果被灵墟洞天作为仙苗," + "在青帝坟墓处为青帝十九代孙附体离去,肉身被锤炼至四极境界。后叶凡与黑皇镇压老妖神识," + "庞博重新掌控自己身躯,取得妖帝古经和老妖本体祭炼成的青莲法宝,习得妖帝九斩和天妖八式," + "但仍伪装成老妖留在妖族。出关后找上叶凡,多次与他共进退。星空古路开启后由此离开北斗," + "被叶凡从妖皇墓中救出,得叶凡授予者字秘、一气化三清,与叶凡同闯试炼古路,一起建设天庭"; // 屏幕的高度 int screenWidth = 0; // 总共可以放多少个字 int count = 0; // textView全部字符的宽度 float textTotalWidth = 0.0f; // textView一个字的宽度 float textWidth = 0.0f; Paint paint = new Paint(); @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); tv_right = (TextView) findViewById(R.id.test_tv_right); tv_bottom = (TextView) findViewById(R.id.test_tv_bottom); final ImageView imageView = (ImageView) findViewById(R.id.test_image); imageView.setImageResource(R.drawable.ee); screenWidth = getWindowManager().getDefaultDisplay().getWidth(); /** * 获取一个字的宽度 */ textWidth = tv_right.getTextSize(); paint.setTextSize(textWidth); /** * 因为图片一开始的时候,高度是测量不出来的,通过增加一个监听器,即可获取其图片的高度和长度 */ ViewTreeObserver vto = imageView.getViewTreeObserver(); vto.addOnPreDrawListener(new ViewTreeObserver.OnPreDrawListener() { public boolean onPreDraw() { if (!imageMeasured) { imageMeasured = true; int height = imageView.getMeasuredHeight(); int width = imageView.getMeasuredWidth(); drawImageViewDone(width, height); } return imageMeasured; } }); } private void drawImageViewDone(int width, int height) { // 一行字体的高度 int lineHeight = tv_right.getLineHeight(); // 可以放多少行 int lineCount = (int) Math.ceil((double) height / (double) lineHeight); // 一行的宽度 float rowWidth = screenWidth - width - tv_right.getPaddingLeft() - tv_right.getPaddingRight(); // 一行可以放多少个字 int columnCount = (int) (rowWidth / textWidth); // 总共字体数等于 行数*每行个数 count = lineCount * columnCount; // 一个TextView中所有字符串的宽度和(字体数*每个字的宽度) textTotalWidth = (float) ((float) count * textWidth); measureText(); tv_right.setText(text.substring(0, count)); // 检查行数是否大于设定的行数,如果大于的话,就每次减少一个字符,重新计算行数与设定的一致 while (tv_right.getLineCount() > lineCount) { count -= 1; tv_right.setText(text.substring(0, count)); } tv_bottom.setPadding(0, lineCount * lineHeight - height, 0, 0); tv_bottom.setText(text.substring(count)); } /** * 测量已经填充的长度,计算其剩下的长度 */ private void measureText() { String string = text.substring(0, count); float size = paint.measureText(string); int remainCount = (int) ((textTotalWidth - size) / textWidth); if (remainCount > 0) { count += remainCount; measureText(); } } }

其中xml文件布局如下:

<?xml version="1.0" encoding="utf-8"?> <ScrollView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <RelativeLayout android:layout_width="fill_parent" android:layout_height="wrap_content" > <ImageView android:id="@+id/test_image" android:layout_width="wrap_content" android:layout_height="wrap_content" android:scaleType="fitXY" /> <TextView android:id="@+id/test_tv_right" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_toRightOf="@id/test_image" android:gravity="fill_horizontal" android:paddingLeft="7dp" android:textSize="16sp" /> <TextView android:id="@+id/test_tv_bottom" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_below="@id/test_image" android:gravity="fill_horizontal" android:textSize="16sp" /> </RelativeLayout> </ScrollView>

代码很少,原理也很简单,后来发现这种做法在大部分手机运行是完美的,但是少部分手机还是有点问题。是什么问题呢,是在我们测量textView的长度的是,因为是我们刚刚进行setText,然后马上进行测量,这样得到的结果是不正确的,所以大家可以优化一下。温馨提示,当我们setText之后,可以延时一些时间再去测量,这样获取的值就是挣钱的了,当然那个延迟的时间很短50毫秒就可以了,因为我们要相信textView的绘制速度还是很快的。

希望本文所述对大家Android程序设计有所帮助。

时间: 2024-11-25 11:41:41

Android实现文字和图片混排(文字环绕图片)效果的相关文章

Android实现文字和图片混排(文字环绕图片)效果_Android

本文实例讲述了Android实现文字和图片混排(文字环绕图片)效果.分享给大家供大家参考,具体如下: 在平时我们做项目中,或许有要对一张图片或者某一个东西进行文字和图片说明,这时候要求排版美观,所以会出现文字和图片混排的情况,如图: 这种情况就是上下两个文字说明是连续在一起的,这就要求我们计算上面的文字说明怎么和下面的文字说明连贯结合在一起呢,这就要求我们进行计算了,下面给出代码,代码中也有详细的注释,原理也很简单. 因为算是比较简单,直接就在activity中去计算了: package com

文字和图片混排

文字和图片 其实这个内容蛮早了,只是今天整理到博客上.自从有了IOS7后,文字的颜色和文字与图片的混排甚至把图片作为表情都可以轻松地实现了.不打算书写了,主体代码粘贴如下,需要细看的直接下载附件就可以了.代码下载 @interface MMTextAttachment : NSTextAttachment { } @end @implementation MMTextAttachment //I want my emoticon has the same size with line's hei

安卓-请问在Android里面怎么实现图文混排

问题描述 请问在Android里面怎么实现图文混排 在Android中怎么多张照片和段落文字混合排版,类似于豆瓣等这些应用. 解决方案 **1. 只用一个TextView来实现:在获取到数据时需要对数据进行分析,分析出文本里的图片元素,然后根据图片元素的大小动态决定图片TextView每一行的字符数和行高(主要是在OnDraw里来实现,行高其实可以是固定的),然后根据行高和行数来得到图片显示区域的高度(因为我们需要对图片进行垂直方向上的居中).然后用 (行高*行数 - 1个行间距 - 图片高度

怎么在word2003中实现文字的纵横混排?

  1.选择要设置的文字,如图所示. 2.在菜单栏的 "格式"找到"文字方向",如图所示. 3.点"文字方向",出现如图所示的"文字方向-主文档",选择一个纵向的文字格式,点击就出现如图所示的文字格式. 4.这时候我们会发"word"和"2003"也是纵向的,这时候我们就运用到"纵横混排",选中"word",找到菜单栏中"格式"

Android中使用TextView实现文字环绕图片效果实例

在平时我们做项目中,或许有要对一张图片或者某一个东西进行文字和图片说明,这时候要求排版美观,所以会出现文字和图片混排的情况,如图: 这种情况就是上下两个文字说明是连续在一起的,这就要求我们计算上面的文字说明怎么和下面的文字说明连贯结合在一起呢,这就要求我们进行计算了,下面给出代码,代码中也有详细的注释,原理也很简单. 因为算是比较简单,直接就在activity中去计算了: package com.example.test; import android.app.Activity; import

base64-android端如何实现图文混排

问题描述 android端如何实现图文混排 服务器传来的数据是html格式的,其中包含文字和图片,并且图片是用base64格式的, 我应该如何在客户端解析这些标签,并且能够将base64转成图片一起显示出来?请赐教 解决方案 使用webview直接能显示html

Word入门动画教程133:纵横混排

纵横混排与改变文字方向(参见Word入门动画教程128)不同,它可以在同一页面中,改变部分文本的 排列方向,由原来的纵向变为横向,原来的横向变为纵向,尤其适用于少量文字(例如日期).操作步骤 如下: 1.选择要改变方向的文本. 2.执行"格式"→"中文版式"→"纵横混排",打开 "纵横混排"对话框. 3.选中"适应行宽"复选项,可使文本旋转方向后自动压缩其高度与该行的高度相同. 4.单击"确定&q

我在android中集成了mupdf,但图文混排的pdf不能解析图片,只显示了文字

问题描述 我在android中集成了mupdf,但图文混排的pdf不能解析图片,只显示了文字 你好,我用官方的 .so 文件,集成到android里面,现在能打开pdf文件,可是图文混排的图全部没有了,只有文字解析,而且没有很好的适应一页,明显下面还有文字没有显示,请指教 另外解析了一个xps文件,结果格式完全不对,图片还漂移 请指教,谢谢

css样式教程:图文混排[图上文字下]

css样式教程:图文混排[图上文字下],标题不知道怎么写所以就搞得很乱,很多的,下我们先看看混文混排的效果图片你就会知道是怎么的效果了哦. 看css 布局代码.  代码如下 复制代码  <ul class="hotGroup">             <li><a href="#"></a><span>圈子名称</span></li>             <li>&