列表图片等分

1.新建一个计算图片高度的类
public class NewRatioImageView extends ImageView {
   
   private float mRatio;

   public NewRatioImageView(Context context) {
      super(context);
   }
   
   public NewRatioImageView(Context context, AttributeSet attrs) {
      super(context, attrs);
      
      TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.NewRatioImageView);
      mRatio = a.getFloat(R.styleable.NewRatioImageView_ratio_f, 0.3f);
      a.recycle();
   }

   protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        int width = MeasureSpec.getSize(widthMeasureSpec);
        int height = Math.round(width * mRatio);
        setMeasuredDimension(width,height);
    }
   
   public void setRatio(float ratio) {
      mRatio = ratio;
      requestLayout();
   }
   
}
2.在布局里引用这个类
<LinearLayout
    android:id="@+id/imgContainer"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginTop="5dp"
    android:orientation="horizontal" >
    <com.yaya.mmbang.widget.NewRatioImageView
        android:id="@+id/iv_image0"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:scaleType="centerCrop"
        android:layout_marginRight="5dp"
        app:ratio_f="1"
        android:visibility="invisible" />
    <com.yaya.mmbang.widget.NewRatioImageView
        android:id="@+id/iv_image1"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:scaleType="centerCrop"
        android:layout_marginRight="5dp"
        app:ratio_f="1"
        android:visibility="invisible" />
    <com.yaya.mmbang.widget.NewRatioImageView
        android:id="@+id/iv_image2"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:scaleType="centerCrop"
        app:ratio_f="1"
        android:visibility="invisible" />
</LinearLayout>
3.在attr里面定义字段
<declare-styleable name="NewRatioImageView">
    <attr name="ratio_f" format="float" />
</declare-styleable>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值