• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
Black_Goat
博客园    首页    新随笔    联系   管理    订阅  订阅

自定义控件-平铺图片

使图片平铺背景

在这里使用自定义控件为了使图片能够铺平整个控件背景。

首先在样式里定义控件和属性

style:
<declare-styleable name="RatioLayout">
<attr name="ratio" format="float"/>
</declare-styleable>
xml:

<com.example.photo.custom.RatioLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
app:ratio="1">

<ImageView
android:id="@+id/module_layout_welcome_iv"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:contentDescription="@string/activity_welcome_iv" />
</com.example.photo.custom.RatioLayout>
java:
public class RatioLayout extends FrameLayout {

private float ratio;

public RatioLayout(@NonNull Context context) {
super(context);
}

public RatioLayout(@NonNull Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
/*获取自定义控件的属性集合*/
TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.RatioLayout);
/*根据id,获取属性值RatioLayout_ratio系统默认控件名_属性名*/
ratio = typedArray.getFloat(R.styleable.RatioLayout_ratio, 0);
/*回收*/
typedArray.recycle();
}

public RatioLayout(@NonNull Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}

@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
/*获取模式*/
int widthMode = MeasureSpec.getMode(widthMeasureSpec);
int heightMode = MeasureSpec.getMode(heightMeasureSpec);
/*获取大小*/
int widthSize = MeasureSpec.getSize(widthMeasureSpec);
int heightSize = MeasureSpec.getSize(heightMeasureSpec);

/*MeasureSpec.AT_MOST 类似match_parent
* MeasureSpec.EXACTLY 类似wrap_content
* MeasureSpec.UNSPECIFIED 未定义*/

if (widthMode == MeasureSpec.EXACTLY && heightMode != MeasureSpec.EXACTLY && ratio > 0) {
/*根据布局推算出图片宽度*/
int imageWidth=widthSize-getPaddingEnd()-getPaddingStart();
/*根据图片宽度,宽高比,推算出图片高度*/
int imageHeight= (int) (imageWidth/ratio+0.5f);
/*根据图片高度算出控件高度*/
heightSize=imageHeight+getPaddingTop()+getPaddingBottom();
/*重新定义*/
heightMeasureSpec= MeasureSpec.makeMeasureSpec(heightSize, MeasureSpec.EXACTLY);
}

super.onMeasure(widthMeasureSpec, heightMeasureSpec);
}
}
 
 
posted @ 2020-09-29 17:15  梦里醉相思  阅读(119)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3