android图片底部居中对齐,Android 解决图文混排,图片和文字居中对齐问题(ImageSpan)...

本文介绍了如何在Android中实现图文混排时图片和文字的居中对齐。通过扩展ImageSpan并重写onDraw()方法,将图片绘制在字体的descent线和ascent的中点位置,从而达到居中效果。文章提供了一个简单的实现方案,并给出了代码示例。
摘要由CSDN通过智能技术生成

一. 概述

众所周知,Android图文混排可以通过SpannableString来实现,通过在相应位置使用ImageSpan替换即可,但是使用过的人会发现,imageSpan只提供了两种对齐方式,如下所示:

/** 底部对齐 */

public static final int ALIGN_BOTTOM = 0;

/** 基线对齐 */

public static final int ALIGN_BASELINE = 1;

但是在大多数时候,我们希望实现图片的中点和文字的中点对齐(视觉设计师肯定会给到这样的要求),那么该怎么办呢?

二. 图文混排,图片居中对齐方案

方案1:

一个比较简单解决方案就是让图片和文字的高度保持一致,这样就变相居中对齐了,那么有一些朋友为难了,视觉给的图片的高度比字体的高度小,这肿么办? 这个问题很好解决,让视觉给你切大一点的图片,即在原来的图片上多切一些透明的白边。(是不是恍然大悟?哈哈)

plus:图片比文字高的情况根本不需要居中对齐。

方案2:

程序员肯定有程序员的方案,那就是扩展继承ImageSpan,重写它的onDraw()方法。这个方案本人参考了网上的一些解决方案,但是都有局限性,有些方案只要设置的TextView行间距或者padding就不能正常工作了。

这篇博客的方案,在设置了行间距的时候,就出现问题了。但是这篇博客把字体绘制的原理说的很清楚了,建议大家先读这篇博客,再来理解本人的做法。

代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值