实现图片放大缩小,点击热点响应事件
来源:互联网 发布:关于人工智能的问题 编辑:程序博客网 时间:2024/06/11 15:13
最近实现一个功能,类似百度地图。条件:一张图片。要求图片可以任意放大缩小移动,点击放缩后图片的热点时弹出popwindow,并且给热点区域添加阴影,显示出热点区。
实现思路:
1.先要实现图片的任意放缩
2.获得热点区域的坐标
3.点击热点区域响应事件
4.点击热点区域弹出popwindows,并指定popwindow的显示位置
5.给热点区域添加背景色
解决方法:
1.网上实现图片任意缩放功能的代码有很多,参考的博客http://yq135314.iteye.com/blog/1997676
2.参考以上博客,下载了DreameWeaver,获取热点坐标
3.获得手指点击时的坐标,根据放缩比例得到原坐标(放缩前),然后判断原坐标是否在热点区域。如在响应事件。
4.得到当前手指点击坐标,在该坐标处添加一个控件,比如button,popwindow的位置就相对于button来设定。
5.给当前图片的热点区域画矩形,并保存为bitmap,然后把这个图形作为放缩操作的图形。
遇到问题:
1.点击热点区域时在该热点区域弹出popwindow。pop的位置有两种,相对于某一view位置和绝对位置。在此处需要使用前者,但是热点区域并没有view,这就需要动态添加view。判断点击区域是否是热点区,若是,则获取当前坐标,并在该点处添加btn,使pop相对btn显示。
2.给图片热点区添加阴影。
//创建原图片bitmap,
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
if (mSourceBitmap != null) {
Canvas c = new Canvas(mSourceBitmap );
paint = new Paint();
paint.setStyle(Paint.Style.FILL);
paint.setColor(Color.BLACK);
// 绘制矩形
canvas.drawRect(10, 10, 100, 100, paint);
canvas.drawBitmap(mSourceBitmap, mMatrix, null);
} else {
LogUtils.d(TAG, "mBlockBitmap is null !");
}
}
//运行结果:一张空白图片,因为新建的一张画布,虽然 Canvas c = new Canvas(mSourceBitmap );但没有对画布保存,所以显示一张空白画布。正确步骤如下:
mSourceBitmap = BitmapFactory.decodeStream(hotImgStream).copy( Bitmap.Config.ARGB_8888, true);
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
if (mSourceBitmap != null) {
mBlockBitmap = Bitmap.createBitmap(mSourceBitmap.getWidth(), mSourceBitmap.getHeight(), Bitmap.Config.ARGB_8888);//创建一个bitmap
Canvas c = new Canvas(mBlockBitmap);//创建一个新画布
c.drawBitmap(mSourceBitmap, 0, 0, null);//画上背景
paint = new Paint();
//这样写画出的矩形是实心的不透明的,setRGB就可以显示成功,不知道为什么
// paint.setAlpha(1);
// paint.setColor(Color.BLUE);
paint.setARGB(50, 128, 138, 135);
pt = new int[mHotAreas.size()][4];
pt = getLocat(mHotAreas);
for (int i = 0; i < mHotAreas.size(); i++) {
c.drawRect(pt[i][0], pt[i][1], pt[i][2], pt[i][3], paint);//画矩形
}
c.save(Canvas.ALL_SAVE_FLAG);//保存画布
canvas.drawBitmap(mBlockBitmap, mMatrix, null);//显示带热点阴影的图
} else {
LogUtils.d(TAG, "mBlockBitmap is null !");
}
}
效果图:
心得:最近一直在告诫自己,进度慢不要紧,重要的是想清楚,思路清晰。就像我在画热点阴影的时候,思路想通了,觉得逻辑上行得通,可是画出的是一张空白,不知道这个空白画布是哪来的,折腾了好久,才发现原来是见了一张空白画布。做任何事,先有个清晰的思路,然后在跟着思路一步步走下去,即时后来出错了,也能大概判断错在哪里,这样比盲目效仿效率更高!敲代码如此,做人做事也一样!
实现思路:
1.先要实现图片的任意放缩
2.获得热点区域的坐标
3.点击热点区域响应事件
4.点击热点区域弹出popwindows,并指定popwindow的显示位置
5.给热点区域添加背景色
解决方法:
1.网上实现图片任意缩放功能的代码有很多,参考的博客http://yq135314.iteye.com/blog/1997676
2.参考以上博客,下载了DreameWeaver,获取热点坐标
3.获得手指点击时的坐标,根据放缩比例得到原坐标(放缩前),然后判断原坐标是否在热点区域。如在响应事件。
4.得到当前手指点击坐标,在该坐标处添加一个控件,比如button,popwindow的位置就相对于button来设定。
5.给当前图片的热点区域画矩形,并保存为bitmap,然后把这个图形作为放缩操作的图形。
遇到问题:
1.点击热点区域时在该热点区域弹出popwindow。pop的位置有两种,相对于某一view位置和绝对位置。在此处需要使用前者,但是热点区域并没有view,这就需要动态添加view。判断点击区域是否是热点区,若是,则获取当前坐标,并在该点处添加btn,使pop相对btn显示。
2.给图片热点区添加阴影。
//创建原图片bitmap,
(错误)mSourceBitmap = BitmapFactory.decodeStream(hotImgStream);//报异常Immutable bitmap passed to Canvas constructor 不允许直接修改res中的文件。
(正确)mSourceBitmap = BitmapFactory.decodeStream(hotImgStream).copy( Bitmap.Config.ARGB_8888, true);@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
if (mSourceBitmap != null) {
Canvas c = new Canvas(mSourceBitmap );
paint = new Paint();
paint.setStyle(Paint.Style.FILL);
paint.setColor(Color.BLACK);
// 绘制矩形
canvas.drawRect(10, 10, 100, 100, paint);
canvas.drawBitmap(mSourceBitmap, mMatrix, null);
} else {
LogUtils.d(TAG, "mBlockBitmap is null !");
}
}
//运行结果:一张空白图片,因为新建的一张画布,虽然 Canvas c = new Canvas(mSourceBitmap );但没有对画布保存,所以显示一张空白画布。正确步骤如下:
mSourceBitmap = BitmapFactory.decodeStream(hotImgStream).copy( Bitmap.Config.ARGB_8888, true);
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
if (mSourceBitmap != null) {
mBlockBitmap = Bitmap.createBitmap(mSourceBitmap.getWidth(), mSourceBitmap.getHeight(), Bitmap.Config.ARGB_8888);//创建一个bitmap
Canvas c = new Canvas(mBlockBitmap);//创建一个新画布
c.drawBitmap(mSourceBitmap, 0, 0, null);//画上背景
paint = new Paint();
//这样写画出的矩形是实心的不透明的,setRGB就可以显示成功,不知道为什么
// paint.setAlpha(1);
// paint.setColor(Color.BLUE);
paint.setARGB(50, 128, 138, 135);
pt = new int[mHotAreas.size()][4];
pt = getLocat(mHotAreas);
for (int i = 0; i < mHotAreas.size(); i++) {
c.drawRect(pt[i][0], pt[i][1], pt[i][2], pt[i][3], paint);//画矩形
}
c.save(Canvas.ALL_SAVE_FLAG);//保存画布
canvas.drawBitmap(mBlockBitmap, mMatrix, null);//显示带热点阴影的图
} else {
LogUtils.d(TAG, "mBlockBitmap is null !");
}
}
效果图:
心得:最近一直在告诫自己,进度慢不要紧,重要的是想清楚,思路清晰。就像我在画热点阴影的时候,思路想通了,觉得逻辑上行得通,可是画出的是一张空白,不知道这个空白画布是哪来的,折腾了好久,才发现原来是见了一张空白画布。做任何事,先有个清晰的思路,然后在跟着思路一步步走下去,即时后来出错了,也能大概判断错在哪里,这样比盲目效仿效率更高!敲代码如此,做人做事也一样!
0 0
- 实现图片放大缩小,点击热点响应事件
- 实现图片放大缩小,点击热点响应事件
- android点击实现图片放大缩小
- 实现点击图片的放大缩小
- 点击图片实现放大或缩小
- 前端jquery实现图片点击放大缩小
- 图片点击放大缩小
- 实现图片的点击放大,再点击缩小
- 图片放大缩小的区域点击事件代码例子
- 图片放大缩小的区域点击事件代码例子
- 图片放大缩小的区域点击事件代码例子
- 图片放大缩小的区域点击事件代码例子
- C#(winform)实现图片的无损放大缩小【点击鼠标滚动键放大缩小】
- 快速实现图片点击放大缩小,支持url
- 实现图片的点击拖动与多指放大缩小
- 支持点击放大缩小图片,拖动放大缩小图片功能
- iOS点击图片放大 再点击缩小
- flex4.6实现图片放大缩小及鼠标拖放事件
- UVa-156 Ananagrams
- 手机浏览器错误提示
- 258 Add Digits
- 求最大值最小值以及第K大值问题(顺序统计量问题)
- 通过扩展改善ASP.NET MVC的验证机制[实现篇]
- 实现图片放大缩小,点击热点响应事件
- FTL常用标签及语法 .
- Leetcode#68||
- window.onresize(当你改变窗口大小的时候会触发这个事件)
- 利用openssl_random_pseudo_bytes和base64_encode函数来生成随机字符串
- server name 问题
- HDU 2709 Sumsets
- iOS项目开发实战——自定义控件背景与颜色
- C++学习——string和string.h