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 图片缩放实例详解,包括了Android 图片缩放实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实现Android中的图片的缩放效果 首先设计布局: 逻辑代码如下: 如果你对矩阵的设置不清楚,还可以使用下列api提供的方法替换上面标记部分的代码: matrix.setScale(0.5f, 1); 注意: 新建矩阵并设置缩放值 M
问题内容: 我为设置背景图片有一个小问题。 这是我在网站上获得的html: 这是CSS: 我不知道为什么按钮的背景仍然是白色。 问题答案: 令人惊讶的是,这里没有答案解决或提及实际问题。 该CSS选择器说:“给我一个元素与ID 里面 一个元素”,就像这样: 但是,您想要的是 带有* id 的元素。而选择器将是(请注意 button 和 #rock 之间缺少的空间)。 * 正如@Greg已经提到的:
问题内容: 如果选择了该面板(单击该面板),则该面板的颜色为蓝色。另外,我在该面板上添加了一个小标志(图像),它表示所选面板之前已被选中。 因此,如果用户看到例如10个面板,其中有4个带有这个小标记,则他知道自己之前已经单击了这些面板。到目前为止,这项工作还不错。现在的问题是我无法显示小标志并使面板同时变为蓝色。 我使用css将面板设置为蓝色,使用设置背景图像。但是背景色似乎在图像上方,因此您看不
问题内容: 这不是关于如何在背景图像上放置文字的常见问题。 我有一个背景图像,我想将其作为叠加层使用-应该在文本上。为简单起见,在现有div上放置另一个div并给出背景图像要困难得多。 背景图片是否有可能位于文字上方? 问题答案: 绝对不可能,而且这样做是正确的。如果您可以将元素的 background 属性用于除 background 之外的其他任何东西,那将是错误的(并且令人困惑)。
问题内容: 我正在创建一个GUI,尽管很简单,但我想让背景图像(2048 X 2048)填满整个窗口,并在左上角放置一个正方形,可以偶尔加载64 X 64图像。在此先感谢提供帮助的任何人:)编辑:我已经知道如何使JFrame设置大小,其图像加载需要帮助。 问题答案: 这是一个在JFrame中添加背景图像的简单示例: 点击这里了解更多信息
问题内容: 这是我的代码,它确实找到了图像,所以这不是我关心的问题,我关心的是如何使该图像成为面板的背景。我正在尝试使用Graphics,但是我不起作用,有什么想法吗?请?? 问题答案: 您的代码中有一个错误。在取消引用之前,将其设置为该行。这肯定会抛出一个。与其声明自己的Graphics对象,不如使用传递给要用于绘画的方法的那个。要在Swing中执行此操作,您应该实现绘制图像的方法,如下所示: