3 回答
TA贡献1817条经验 获得超6个赞
这是我解决类似问题的方法。
首先复制要用作图像贴图的图像,然后为每个部分上色。不用说,每个部分都有不同的颜色:D。然后在布局中创建两个ImageView。将第一个的背景设置为要显示的图像,将第二个的背景设置为其中的彩色。
然后将第二个ImageView的可见性设置为invisible。如果此时运行该程序,则应该看到要显示的图像。然后使用OnTouch侦听器并获取您触摸的像素的颜色。颜色将与彩色图像的颜色相对应。
需要将以下getColour方法传递给touch事件的x和y坐标。R.id.img2是不可见的图像。
private int getColour( int x, int y)
{
ImageView img = (ImageView) findViewById(R.id.img2);
img.setDrawingCacheEnabled(true);
Bitmap hotspots=Bitmap.createBitmap(img.getDrawingCache());
img.setDrawingCacheEnabled(false);
return hotspots.getPixel(x, y);
}
希望这对您有所帮助:)。
TA贡献1864条经验 获得超6个赞
我像Scotty所说的那样戴了口罩,但是遇到了更多的问题。基本上,getPixel返回的颜色与遮罩文件中的颜色略有不同。我要做的是在禁用缩放和使用全色选项的情况下将掩码加载到内存中:
BitmapFactory.Options bitmapOptions = new BitmapFactory.Options();
bitmapOptions.inTargetDensity = 1;
bitmapOptions.inDensity = 1;
bitmapOptions.inDither = false;
bitmapOptions.inScaled = false;
bitmapOptions.inPreferredConfig = Bitmap.Config.ARGB_8888;
mask = BitmapFactory.decodeResource(appContext.getResources(), resMask, bitmapOptions);
然后我从缩放后的图像中查找坐标,如下所示:
ImageView map = (ImageView) findViewById(R.id.image);
Drawable drawable = map.getDrawable();
Rect imageBounds = drawable.getBounds();
int scaledHeight = imageBounds.height();
int scaledWidth = imageBounds.width();
int scaledImageOffsetX = Math.round(event.getX()) - imageBounds.left;
int scaledImageOffsetY = Math.round(event.getY()) - imageBounds.top;
int origX = (scaledImageOffsetX * mask.getWidth() / scaledWidth);
int origY = (scaledImageOffsetY * mask.getHeight() / scaledHeight);
if(origX < 0) origX = 0;
if(origY < 0) origY = 0;
if(origX > mask.getWidth()) origX = mask.getWidth();
if(origY > mask.getHeight()) origY = mask.getHeight();
然后我应用了mask.getPixel(origX,origY)。仅当在ImageView中使用android:scaleType =“ fitXY”缩放图像时,此功能才有效,否则会关闭坐标。
TA贡献1812条经验 获得超5个赞
在区域上像素颜色的一致性方面仍然存在问题。最终对我有用的是确保我使用带有索引颜色的PNG图像作为蒙版。在我的情况下,我使用了经过网络优化的调色板(216种颜色),并确保我选择的所有颜色都是该调色板中的值。进行此更改后,我在整个区域中获得了相同的颜色值。
- 3 回答
- 0 关注
- 604 浏览
添加回答
举报