:
> FrameLayout(标记为红色)
> Source ImageView(黑色)
> Object(imageview)与OnTouchListener(橙色)
Via Object with OnTouchListener,我想显示位图的一部分,它们填充在imageview(源imageview)上.
所以这不是一个问题,我这样做:
Bitmap bt = Bitmap.createBitmap(sourceBitmap,event.getX(),event.getY(),250,250);
哪里:
> SourceBitmap – 是添加到ImageView的图像
> event.getX()/ event.getY()是一个坐标,我开始绘制位图的一部分
> 250,250 – 其大小的部分位图(部分).
结果是:
所以问题出现了,当我的对象(用touchlistener)进入边界(我已经使这个橙色对象的可能性,与Object.width()/ 2)离开界限.
>位图的一部分
>第二部分是framelayout背景的颜色.
我在当下时刻尝试过的
- public boolean onTouch(View view,MotionEvent event) {
- switch (event.getAction()) {
- case MotionEvent.ACTION_MOVE:
- //i want to draw bigger portion then corrds
- int CurrentX = (int)view.getX() - (view.getWidth());
- int CurrentY = (int)view.getY() - (view.getHeight());
- //case,when object is going out of border
- if(CurrentX <= 0)
- {
- Paint paint = new Paint();
- paint.setStyle( Style.FILL );
- paint.setColor( Color.RED );
- mBitmap = Bitmap.CreateBitmap(sourceBitmap,(int)view.getX() + Math.abs(CurrentX),(int)view.getY(),250);
- Canvas canvas = new Canvas(mBitmap);
- canvas.drawBitmap(mBitmap,new Rect((int)view.getX()+Math.abs(CurrentX),250-Math.abs(CurrentX),250),new RectF(Math.abs(CurrentX),paint);
- }
- break;
- }
- return true;
- }
- }
有什么建议么?谢谢!
解决方法
这很复杂,但结果相当不错.
开始了:
所以对于我的情况(当OnTouchListener的对象可以离开X和Y轴上的边框时),我已经做了Post Conditions(某种规定).
条件
Width = imageView的宽度,我想显示结果.
Height = imageView的高度,我想显示结果;
左边
> X_Coord< 0&& Y_Coord - 高度/ 2 < 0&& Y_Coord< Bitmap.Height
这是我们的顶级区域.
> X_Coord< 0&& Y_Coord - Height / 2> 0&& Y_Coord< Bitmap.Height
这是我们的中间区.
> X_Coord< 0&& Y_Coord - Height / 2> 0&& Y_Coord> Bitmap.Height
这是我们的底层.
右边
> X_Coord> Bitmap.Height&& Y_Coord – Height / 2> 0&& Y_Coord Bitmap.Height
这是我们的中间区.
> X_Coord> Bitmap.Height&& Y_Coord – 高度/ 2 < 0&& Y_Coord< Bitmap.Height
这是我们的顶级区域.
> X_Coord> Bitmap.Height&& Y_Coord – Height / 2> 0&& Y_Coord> Bitmap.Height
这是我们的底层.
Standart(中间区域,不会左侧或右侧)
> X_Coord – Width / 2> 0&& X_Coord< Bitmap.Width&& Y_Coord - 高度/ 2 < 0&& Y_Coord< Bitmap.Height
这是我们的顶级区域.
> X_Coord – Width / 2> 0&& X_Coord< Bitmap.Width&& Y_Coord - Height / 2> 0&& Y_Coord> Bitmap.Height
这是我们的底层.
> X_Coord – Width / 2> 0&& X_Coord< Bitmap.Width&& Y_Coord - Height / 2> 0&& Y_Coord< Bitmap.Height
这是我们的中间区.
所以通过这个“条件”,我在我的MotionEvent.ACTION_MOVE情况下绘制位图的一部分.
我们来看一些例子:
- public boolean onTouch(View view,MotionEvent event) {
- switch (event.getAction()) {
- case MotionEvent.ACTION_MOVE:
- int Width = ResultImgView.getWidth();
- int Height = ResultImgView.getHeight();
- //paint for our Red background
- Paint paint = new Paint();
- paint.setStyle( Style.FILL );
- paint.setColor( Color.RED );
- Bitmap mBitmap = null;
- Canvas canvas = null;
- //Our Condition
- if(view.getX() - Width / 2 >= SourceBitmap.getWidth()
- && view.getY() - Height / 2 > 0 && view.getY() + Height / 2 < SourceBitmap.getHeight())
- {
- //Nice,we entered here. Seems that we're now located at RightSide at Middle position
- //So let's draw part of bitmap.
- //our margin for X coords
- int Difference = (int)((view.getX() - Width / 2 ) - SourceBitmap.getWidth();
- //dont forget to put margin
- //BTW we're now took portion of bitmap
- mBitmap = Bitmap.createBitmap(SourceBitmap,((int)view.getX() - Width / 2) - Difference,(int)view.getY() - Height / 2,Width,Height);
- canvas = new Canvas(mBitmap);
- //draw rect
- canvas.drawRect(0,mBitmap.getWidth(),mBitmap.getHeight(),paint);
- //draw portion of bitmap
- canvas.drawBitmap(mBitmap,new Rect(Difference,mBitmap.getHeight()),new Rect(0,mBitmap.getWidth() - Difference,null);
- //and that's all!
- }
- //do the same for other condition....etc
- break;
- }
- return true;
- }
请享用!
PS对不起我的eng