当我在布局文件中包含以下XML
内容时,我可以看到下图。如果你看到它,你会意识到它TextView
有顶部和底部空间。
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="E1"
android:background="#ff00ff00"/>
我想删除空间。如何删除它?这叫什么?如果有人有线索..请告诉我。提前致谢。
当我在布局文件中包含以下XML
内容时,我可以看到下图。如果你看到它,你会意识到它TextView
有顶部和底部空间。
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="E1"
android:background="#ff00ff00"/>
我想删除空间。如何删除它?这叫什么?如果有人有线索..请告诉我。提前致谢。
试试看android:includeFontPadding="false"
是否有帮助。根据我的经验,这将有所帮助,但无法将 TextView 尺寸减小到精确的像素完美文本大小。
唯一的替代方法可能会或可能不会给出更好的结果,那就是作弊并硬连线尺寸以匹配文本大小,例如,"24sp"
而不是"wrap_content"
高度。
我有同样的问题。属性android:includeFontPadding="false"
对我不起作用。我以这种方式解决了这个问题:
public class TextViewWithoutPaddings extends TextView {
private final Paint mPaint = new Paint();
private final Rect mBounds = new Rect();
public TextViewWithoutPaddings(Context context) {
super(context);
}
public TextViewWithoutPaddings(Context context, AttributeSet attrs) {
super(context, attrs);
}
public TextViewWithoutPaddings(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
@Override
protected void onDraw(@NonNull Canvas canvas) {
final String text = calculateTextParams();
final int left = mBounds.left;
final int bottom = mBounds.bottom;
mBounds.offset(-mBounds.left, -mBounds.top);
mPaint.setAntiAlias(true);
mPaint.setColor(getCurrentTextColor());
canvas.drawText(text, -left, mBounds.bottom - bottom, mPaint);
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
calculateTextParams();
setMeasuredDimension(mBounds.width() + 1, -mBounds.top + 1);
}
private String calculateTextParams() {
final String text = getText().toString();
final int textLength = text.length();
mPaint.setTextSize(getTextSize());
mPaint.getTextBounds(text, 0, textLength, mBounds);
if (textLength == 0) {
mBounds.right = mBounds.left;
}
return text;
}
}
android:includeFontPadding="false"
相当不错,但它并没有准确地得到它。有时您需要边界线的准确性,因此您可以通过应用负边距自己弄清楚:
尝试将底部和顶部边距设置为负值。
像这样的东西:
android:layout_marginTop="-5dp"
android:layout_marginBottom="-5dp"
相应地调整值。
这是拯救我们一天的代码。它是使用maksimko的 mono C# 代码改编的:
public class TopAlignedTextView extends TextView {
public TopAlignedTextView(Context context) {
super(context);
}
/*This is where the magic happens*/
@Override
protected void onDraw(Canvas canvas){
float offset = getTextSize() - getLineHeight();
canvas.translate(0, offset);
super.onDraw(canvas);
}
}
仍然必须玩弄,textView.setIncludeFontPadding(false)
因为我们要TextViews
与不同的字体大小对齐。
我遇到了同样的问题。这是一个很好的答案:如何将文本对齐到 TextView 的顶部?
但是代码有点未完成,并且不支持所有字体大小。换行
int additionalPadding = TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 5, getContext().getResources().getDisplayMetrics());
至
int additionalPadding = getTextSize() - getLineHeight();
完整的 C# 代码(单声道)删除顶部偏移:
public class TextControl : TextView {
public TextControl (Context context) : base (context)
{
SetIncludeFontPadding (false);
Gravity = GravityFlags.Top;
}
protected override void OnDraw (Android.Graphics.Canvas canvas)
{
if (base.Layout == null)
return;
Paint.Color = new Android.Graphics.Color (CurrentTextColor);
Paint.DrawableState = GetDrawableState ();
canvas.Save ();
var offset = TextSize - LineHeight;
canvas.Translate (0, offset);
base.Layout.Draw (canvas);
canvas.Restore ();
}
}
只是想添加到DynamicMind的答案中,您看到 TextViews 周围的间距的原因是在他们默认使用的9-patch 背景中填充。
9-patch 技术允许您指定一个内容区域,它实际上是填充。除非您明确设置视图的填充,否则将使用该填充。例如,当您以编程方式将 9-patch 背景设置为已设置填充的视图时,它们将被覆盖。反之亦然,如果您设置填充,它们会覆盖 9-patch 背景设置的内容。
不幸的是,在 XML 布局中,无法确定这些操作的顺序。我认为仅从 TextViews 中删除背景会有所帮助:
android:background="@null"
public class TopAlignedTextView extends TextView {
public TopAlignedTextView(Context context, AttributeSet attrs) {
this(context, attrs, 0);
}
public TopAlignedTextView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs);
setIncludeFontPadding(false); //remove the font padding
setGravity(getGravity() | Gravity.TOP);
}
@Override
protected void onDraw(Canvas canvas) {
TextPaint textPaint = getPaint();
textPaint.setColor(getCurrentTextColor());
textPaint.drawableState = getDrawableState();
canvas.save();
//remove extra font padding
int yOffset = getHeight() - getBaseline();
canvas.translate(0, - yOffset / 2);
if (getLayout() != null) {
getLayout().draw(canvas);
}
canvas.restore();
}
}
您是否定义了布局边距?例如:
android:layout_marginTop="5dp"
否则,如果您的文本视图被包裹在 LinearLayout 或其他容器中,那么该冷视图也有填充或边距。
稍微修改了这个AppCompatTextView
答案以使用 kotlin class 和 extend ,修剪垂直填充。
它允许设置android:fontFamily
。方法calculateTextParams()
从onDraw()
性能转移。未针对多行文本进行测试:
import android.content.Context
import android.graphics.Canvas
import android.graphics.Rect
import android.util.AttributeSet
import androidx.appcompat.widget.AppCompatTextView
class NoPaddingTextView : AppCompatTextView
{
private val boundsRect = Rect()
private val textParams = calculateTextParams()
constructor(context : Context?)
: super(context)
constructor(context : Context?, attrs : AttributeSet?)
: super(context, attrs)
constructor(context : Context?, attrs : AttributeSet?, defStyleAttr : Int)
: super(context, attrs, defStyleAttr)
override fun onDraw(canvas : Canvas)
{
with(boundsRect) {
paint.isAntiAlias = true
paint.color = currentTextColor
canvas.drawText(textParams,
-left.toFloat(),
(-top - bottom).toFloat(),
paint)
}
}
override fun onMeasure(widthMeasureSpec : Int, heightMeasureSpec : Int)
{
super.onMeasure(widthMeasureSpec, heightMeasureSpec)
calculateTextParams()
setMeasuredDimension(boundsRect.width() + 1, -boundsRect.top + 1)
}
private fun calculateTextParams() : String
{
return text.toString()
.also {text ->
text.length.let {textLength ->
paint.textSize = textSize
paint.getTextBounds(text, 0, textLength, boundsRect)
if(textLength == 0) boundsRect.right = boundsRect.left
}
}
}
}
android:background="@android:drawable/editbox_background"
使用它根据你改变它你想要editbox_background。因为android提供了一些像上面的代码一样的内置背景,可以根据您的要求进行选择。可能对你有帮助。
在 LinearLayout 内部,默认填充可能是一个问题。尝试将其设置为 0dp。它对我有用。
TopAlignedTextView代码答案:TopAlignedTextView@GitHub
通过布局使用它:
<com.github.captain_miao.view.TopAlignedTextView
android:id="@+id/text_a"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:text="@string/text_demo_a"
/>
我解决这个问题的方法很老套,但我设法通过将文本视图的高度设置为静态并摆弄它直到它几乎不适合文本来让文本坐在我想要的位置。就我而言,我使用的字体样式的高度为 64sp,因此我将 textview 的高度设置为 50sp,它工作正常。我还必须将 foreground_gravity 设置为底部。
机器人:includeFontPadding="假"