Android 背景图片的缩放实现

 更新时间:2016年11月11日 16:05:44   投稿:lqh  
这篇文章主要介绍了Android 背景图片的缩放实现的相关资料,需要的朋友可以参考下

Android 背景图片的缩放

 ONE Goal ,ONE Passion !

我们看到一些效果,控件中的背景图片会慢慢变大,但是控件不会随着图片的放大而变大.效果如下:

分析:

想让图片变大,而且控件本身大小不能改变,那么就要改变图片自身大小,而不能改变控件大小.

实现原理:

1,首先拿到我们要放大的图片bitmap.

2,使用Bitmap.createBitmap().创建一个bitmap的副本.

3,使用matrix去改变图片副本本身大小

4,使用ValueAnimator去根据变化率将副本绘制出来.

自定义View

 public class ScaleImage extends View {

  /**
   * 设置的背景图片
   */
  private Drawable background;
  /**
   * 画布的背景图片
   */
  private Bitmap bitmapCopy;
  /**
   * 跟随动画实时更新的 放大比例
   */
  float scal = 1f;

  /**
   * 让原图放大 1.3倍,这个值可以随意更改.目的是让原图填充满控件
   */
  private float orgFrac = 1.3f;
  /**
   * 控件宽
   */
  private int widthSize;
  /**
   * 控件高
   */
  private int heightSize;
  private float downY;
  private float downX;


  public ScaleImage(Context context) {
    this(context, null);
  }

  public ScaleImage(Context context, AttributeSet attrs) {
    this(context, attrs, 0);
  }

  public ScaleImage(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
  }

  @Override
  protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
    super.onMeasure(widthMeasureSpec, heightMeasureSpec);


    widthSize = MeasureSpec.getSize(widthMeasureSpec);
    heightSize = MeasureSpec.getSize(heightMeasureSpec);


  }

  @Override
  protected void onDraw(final Canvas canvas) {
    super.onDraw(canvas);


    if (background != null) {
      BitmapDrawable bd = (BitmapDrawable) background;
      final Bitmap bitmap = bd.getBitmap();


      final Matrix matrix = new Matrix();

      bitmapCopy = Bitmap.createBitmap(bitmap, 0, 0,
          bitmap.getWidth(), bitmap.getHeight(),
          matrix, true);


      /**
       * float sx, float sy, float px, float py
       *
       * sx,sy x,y方向缩放比例
       * px,py 以px py为轴心进行缩放
       * 放大比例加了默认的orgFrac.是为了在还没有开始缩放时
       * 放图片能够填充控件.如果图片过小的话,可能控件和图片
       * 之间会有边界空白
       *
       * 注意: 这里的px py :matrix作用于哪个对象上,那么px,py就是对象上的坐标点
       * 如 : 这里就是 bitmapCopy 上的px,py坐标点.
       */

      matrix.setScale(orgFrac + scal, 1, bitmapCopy.getWidth() / 2, bitmapCopy.getHeight() / 2);



      canvas.drawBitmap(bitmapCopy, matrix, null);

    }


  }

  /**
   * 开始缩放
   *
   * @param drawableId 需要放大的背景图片
   */
  public void startScale(int drawableId) {


    background = getResources().getDrawable(drawableId);
    if (background == null) {
      throw new RuntimeException("background must not null");
    } else {


      ValueAnimator animator = ValueAnimator.ofFloat(0, 1);
      animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
        @Override
        public void onAnimationUpdate(ValueAnimator animation) {

          float fraction = (float) animation.getAnimatedValue();

          scal = (float) (0.5 * fraction);
          invalidate();


        }
      });

      animator.setDuration(5000);
      animator.setInterpolator(new BounceInterpolator());

      animator.start();

    }

  }

  @Override
  public boolean onTouchEvent(MotionEvent event) {

    switch (event.getAction()) {
      case MotionEvent.ACTION_DOWN:

        downY = event.getY();
        downX = event.getX();

        break;
      case MotionEvent.ACTION_UP:

        float upY = event.getY();
        float upX = event.getX();


        if (Math.abs(upY - downY) < 5 && Math.abs(upX - downX) < 5) {
          listener.backgroundClick();
        }

        break;
    }


    return true;
  }

  OnBackgroundCilckListener listener;

  /**
   * 点击事件的监听
   *
   * @param listener
   */
  public void addBackgroundCilckListener(OnBackgroundCilckListener listener) {
    this.listener = listener;
  }


  public interface OnBackgroundCilckListener {
    void backgroundClick();
  }


  }

跑起来

 image = (ScaleImage) findViewById(R.id.image);

    image.startScale(R.drawable.parallax_img);

    image.addBackgroundCilckListener(new ScaleImage.OnBackgroundCilckListener() {
      @Override
      public void backgroundClick() {

      }
    });

小提琴家

matrix使用待续

好了.直接使用控件,我们将资源文件中的Drawable传入就可以了.

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关文章

  • Android中BaseAdapter的用法分析与理解

    Android中BaseAdapter的用法分析与理解

    这篇文章主要介绍了Android中BaseAdapter的用法分析与理解,结合一个项目开发中BaseAdapter的使用分析了BaseAdapter的功能、作用及用法理解,需要的朋友可以参考下
    2016-08-08
  • Android编程实现对文件夹里文件排序的方法

    Android编程实现对文件夹里文件排序的方法

    这篇文章主要介绍了Android编程实现对文件夹里文件排序的方法,涉及Android文件操作的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-01-01
  • Android网络通信基础类源码分析讲解

    Android网络通信基础类源码分析讲解

    这篇文章主要介绍了Android网络通信基础类源码,包括了Handler、Looper、Thread的分析讲解,对日常开发学习很有帮助,需要的朋友可以参考下
    2024-05-05
  • Android控件系列之CheckBox使用介绍

    Android控件系列之CheckBox使用介绍

    CheckBox和Button一样,也是一种古老的控件,它的优点在于,不用用户去填写具体的信息,只需轻轻点击,缺点在于只有“是”和“否”两种情况,但我们往往利用它的这个特性,来获取用户的一些信息
    2012-11-11
  • Android 连接蓝牙扫码器无输入框的实现

    Android 连接蓝牙扫码器无输入框的实现

    这篇文章主要介绍了Android 连接蓝牙扫码器无输入框的实现,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • Android录制语音文件wav转mp3的方法示例

    Android录制语音文件wav转mp3的方法示例

    这篇文章主要介绍了Android录制语音文件wav转mp3的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • Android数字选择器NumberPicker使用详解

    Android数字选择器NumberPicker使用详解

    这篇文章主要为大家详细介绍了Android数字选择器NumberPicker的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08
  • Android之网络通信案例分析

    Android之网络通信案例分析

    由于一个项目的需要,我研究了一下android的网络通信方式,大体和java平台的很相似,需要的朋友可以参考下
    2012-11-11
  • Android自定义控件实现颜色选择器

    Android自定义控件实现颜色选择器

    这篇文章主要为大家详细介绍了Android自定义控件实现颜色选择器,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-06-06
  • Android 设置主题实现点击波纹效果的示例

    Android 设置主题实现点击波纹效果的示例

    本篇文章主要介绍了Android 设置主题实现点击波纹效果的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11

最新评论