Answers:
编辑:一种不依赖于布局类型的更通用的方法(除了它是一种支持边距的布局类型):
public static void setMargins (View v, int l, int t, int r, int b) {
if (v.getLayoutParams() instanceof ViewGroup.MarginLayoutParams) {
ViewGroup.MarginLayoutParams p = (ViewGroup.MarginLayoutParams) v.getLayoutParams();
p.setMargins(l, t, r, b);
v.requestLayout();
}
}
您应该检查文档中的TextView。基本上,您将需要获取TextView的LayoutParams对象,并修改边距,然后将其设置回TextView。假设它在LinearLayout中,请尝试如下操作:
TextView tv = (TextView)findViewById(R.id.my_text_view);
LinearLayout.LayoutParams params = (LinearLayout.LayoutParams)tv.getLayoutParams();
params.setMargins(0, 0, 10, 0); //substitute parameters for left, top, right, bottom
tv.setLayoutParams(params);
我现在无法对其进行测试,因此我的转换可能会有点偏离,但是需要修改LayoutParams来更改边距。
不要忘记,如果您的TextView位于其中,例如 RelativeLayout,则应使用RelativeLayout.LayoutParams而不是LinearLayout.LayoutParams
使用LayoutParams(如前所述)。但是要小心选择哪个LayoutParams。根据https://stackoverflow.com/a/11971553/3184778, “您需要使用与您正在处理的视图的PARENT相关的视图,而不是与实际视图相关的视图”
例如,如果TextView在TableRow中,则需要使用TableRow.LayoutParams而不是RelativeLayout或LinearLayout
使用此功能设置所有页边距类型
public void setViewMargins(Context con, ViewGroup.LayoutParams params,
int left, int top , int right, int bottom, View view) {
final float scale = con.getResources().getDisplayMetrics().density;
// convert the DP into pixel
int pixel_left = (int) (left * scale + 0.5f);
int pixel_top = (int) (top * scale + 0.5f);
int pixel_right = (int) (right * scale + 0.5f);
int pixel_bottom = (int) (bottom * scale + 0.5f);
ViewGroup.MarginLayoutParams s = (ViewGroup.MarginLayoutParams) params;
s.setMargins(pixel_left, pixel_top, pixel_right, pixel_bottom);
view.setLayoutParams(params);
}
所述核心KTX模块提供了扩展对于那些Android框架的一部分,公共库androidx.core.view
其中。
dependencies {
implementation "androidx.core:core-ktx:{latest-version}"
}
以下扩展功能可轻松处理页边距:
setMargins()
扩展功能:设置在所有轴的利润ViewGroup
的MarginLayoutParams
。(尺寸必须以像素为单位,如果要使用dp,请参阅最后一节)
inline fun MarginLayoutParams.setMargins(@Px size: Int): Unit
// E.g. 16px margins
val params = (myView.layoutParams as ViewGroup.MarginLayoutParams)
params.setMargins(16)
updateMargins()
扩展功能:更新的利润率在ViewGroup
的ViewGroup.MarginLayoutParams
。
inline fun MarginLayoutParams.updateMargins(
@Px left: Int = leftMargin,
@Px top: Int = topMargin,
@Px right: Int = rightMargin,
@Px bottom: Int = bottomMargin
): Unit
// Example: 8px left margin
params.updateMargins(left = 8)
updateMarginsRelative()
扩展功能:更新在相对边缘ViewGroup
的MarginLayoutParams
(开始/结束,而不是左/右)。
inline fun MarginLayoutParams.updateMarginsRelative(
@Px start: Int = marginStart,
@Px top: Int = topMargin,
@Px end: Int = marginEnd,
@Px bottom: Int = bottomMargin
): Unit
// E.g: 8px start margin
params.updateMargins(start = 8)
以下扩展属性很容易获得当前边距:
inline val View.marginBottom: Int
inline val View.marginEnd: Int
inline val View.marginLeft: Int
inline val View.marginRight: Int
inline val View.marginStart: Int
inline val View.marginTop: Int
// E.g: get margin bottom
val bottomPx = myView1.marginBottom
dp
代替px
:如果要使用dp
(与密度无关的像素)代替px
,则需要先进行转换。您可以使用以下扩展属性轻松地做到这一点:
val Int.px: Int
get() = (this * Resources.getSystem().displayMetrics.density).toInt()
然后,您可以调用以前的扩展功能,例如:
params.updateMargins(start = 16.px, end = 16.px, top = 8.px, bottom = 8.px)
val bottomDp = myView1.marginBottom.dp
旧答案:
在Kotlin中,您可以声明扩展函数,例如:
fun View.setMargins(
leftMarginDp: Int? = null,
topMarginDp: Int? = null,
rightMarginDp: Int? = null,
bottomMarginDp: Int? = null
) {
if (layoutParams is ViewGroup.MarginLayoutParams) {
val params = layoutParams as ViewGroup.MarginLayoutParams
leftMarginDp?.run { params.leftMargin = this.dpToPx(context) }
topMarginDp?.run { params.topMargin = this.dpToPx(context) }
rightMarginDp?.run { params.rightMargin = this.dpToPx(context) }
bottomMarginDp?.run { params.bottomMargin = this.dpToPx(context) }
requestLayout()
}
}
fun Int.dpToPx(context: Context): Int {
val metrics = context.resources.displayMetrics
return TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, this.toFloat(), metrics).toInt()
}
然后您可以这样称呼它:
myView1.setMargins(8, 16, 34, 42)
要么:
myView2.setMargins(topMarginDp = 8)