gpt4 book ai didi

android - 如何在覆盖其他图像后合并/保存图像?

转载 作者:行者123 更新时间:2023-11-29 17:38:32 25 4
gpt4 key购买 nike

我正在实现一个应用程序,其中有两个图像。第一张图片是静态的,或者更确切地说,Android“拖放”概念的“放置目标”,第二张图片是“可拖动”。可拖动的图像被拖动并放置在另一个图像上。到目前为止,应用程序工作正常,但我仍然不知道如何保存这个重叠的图像。

在这里我提供我到目前为止所做的:

DragNDropActivity.java

private static final String TAG = DragNDropActivity.class.getSimpleName();
private ImageView m_ivImage1, finalImage, sourceImage, targetImage,
testImage;
private int m_counter = 0;
float m_lastTouchX, m_lastTouchY, m_posX, m_posY, m_prevX, m_prevY,
m_imgXB, m_imgYB, m_imgXC, m_imgYC, m_dx, m_dy;
private LinearLayout m_llTop;
private AbsoluteLayout m_alTop;
private Button m_btnAddView, m_btnRemove, saveImage;
private Context m_context;

@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.drag_drop_layout);

m_context = this;
testImage = new ImageView(m_context);

m_prevX = 0;
m_prevY = 0;
m_imgXB = 50;
m_imgYB = 100;
m_imgXC = 150;
m_imgYC = 100;

m_ivImage1 = (ImageView) findViewById(R.id.ddivImage1);
m_llTop = (LinearLayout) findViewById(R.id.ddllTop);
m_alTop = (AbsoluteLayout) findViewById(R.id.ddalTop);
m_btnAddView = (Button) findViewById(R.id.ddbtnAdd);
m_btnRemove = (Button) findViewById(R.id.ddbtnRemove);
finalImage = (ImageView) findViewById(R.id.finalImage);
saveImage = (Button) findViewById(R.id.saveImage);

m_ivImage1.setOnTouchListener(m_onTouchListener);
m_btnAddView.setOnClickListener(m_onClickListener);
m_btnRemove.setOnClickListener(m_onClickListener);
saveImage.setOnClickListener(m_onClickListener);

//Test code For Merging two images
Bitmap bottomImage = BitmapFactory.decodeFile(Environment.getExternalStorageDirectory().getPath() + "/android.jpg");
Bitmap topImage = BitmapFactory.decodeFile(Environment.getExternalStorageDirectory().getPath() + "/kitkat.jpg");

Bitmap mutableBitmap = bottomImage.copy(Bitmap.Config.ARGB_8888, true);
// use the canvas to combine them.
// Start with the first in the constructor..
Canvas comboImage = new Canvas(mutableBitmap);
// Then draw the second on top of that
comboImage.drawBitmap(topImage, 10f, 10f, null);

// bottomImage is now a composite of the two.

// To write the file out to the SDCard:
OutputStream os = null;
try
{
os = new FileOutputStream(Environment.getExternalStorageDirectory().getPath() + "/myNewFileName.jpg");
mutableBitmap.compress(Bitmap.CompressFormat.PNG, 50, os);
}
catch (IOException e)
{
e.printStackTrace();
}
//End of Test Code

}

/**
* Common click listener for clickable controls
*/
OnClickListener m_onClickListener = new OnClickListener()
{

@Override
public void onClick(View p_v)
{
switch (p_v.getId())
{
case R.id.ddbtnAdd:
addView();
break;
case R.id.ddbtnRemove:
removeView();
break;
case R.id.saveImage:
saveImage();
break;
default:
break;
}
}
};

@TargetApi(Build.VERSION_CODES.JELLY_BEAN)
private void saveImage()
{
Drawable sourceDrawable = sourceImage.getDrawable();
// Drawable targetDrawable = targetImage.getDrawable();

finalImage = new ImageView(m_context);

if (null != testImage.getBackground())
{
//imageview have image

Log.d(TAG, "Image is not null in SaveImage");
finalImage.setVisibility(View.VISIBLE);
finalImage.setBackgroundDrawable(testImage.getBackground());
}
else
{
//imageview have no image
Log.d(TAG, "Image is null in SaveImage");
}
}

/**
* Touch listener for view
*/
OnTouchListener m_onTouchListener = new OnTouchListener()
{

@Override
public boolean onTouch(View p_v, MotionEvent p_event)
{
switch (p_event.getAction())
{
case MotionEvent.ACTION_DOWN:
{
m_lastTouchX = p_event.getX();
m_lastTouchY = p_event.getY();

break;
}
case MotionEvent.ACTION_UP:
{
//It indicates that the pressure on image is released and it is stable now i.e it is not in motion.
//Todo Save final image
// saveImage();
break;
}

case MotionEvent.ACTION_MOVE:
{
m_dx = p_event.getX() - m_lastTouchX;
m_dy = p_event.getY() - m_lastTouchY;

m_posX = m_prevX + m_dx;
m_posY = m_prevY + m_dy;

if (m_posX > 0 && m_posY > 0 && (m_posX + p_v.getWidth()) < m_alTop.getWidth() && (m_posY + p_v.getHeight()) < m_alTop.getHeight())
{
p_v.setLayoutParams(new AbsoluteLayout.LayoutParams(p_v.getMeasuredWidth(), p_v.getMeasuredHeight(), (int) m_posX, (int) m_posY));

m_prevX = m_posX;
m_prevY = m_posY;

}

break;

}

}
return true;
}
};

View.OnDragListener m_dragListener = new View.OnDragListener()
{
@Override
public boolean onDrag(View view, DragEvent dragEvent)
{
Log.d(" Drag Event", "Drop Event " + dragEvent.getAction());

if (dragEvent.getAction() == DragEvent.ACTION_DROP)
{
Log.d(" Drag Event", "Drop Ended ");
}

return true;
}
};

/**
* Add view dynamically for drag and drop
*/
private void addView()
{
sourceImage = new ImageView(m_context);
targetImage = new ImageView(m_context);
TextView m_tv = new TextView(m_context);
if (m_counter < 6)
{
if (m_counter % 2 == 0)
{

sourceImage.setBackgroundResource(R.drawable.ic_launcher);

//m_tv.setText("Hello! Drag Me! ");
m_alTop.addView(m_tv, new LayoutParams(android.view.ViewGroup.LayoutParams.WRAP_CONTENT, android.view.ViewGroup.LayoutParams.WRAP_CONTENT, ((int) m_imgXB), ((int) m_imgYB)));
m_alTop.addView(sourceImage, new LayoutParams(android.view.ViewGroup.LayoutParams.WRAP_CONTENT, android.view.ViewGroup.LayoutParams.WRAP_CONTENT, ((int) m_imgXB), ((int) m_imgYB)));
}
else
{
targetImage.setBackgroundResource(android.R.drawable.star_big_on);
m_alTop.addView(targetImage, new LayoutParams(android.view.ViewGroup.LayoutParams.WRAP_CONTENT, android.view.ViewGroup.LayoutParams.WRAP_CONTENT, ((int) m_imgXC), ((int) m_imgYC)));
}
m_counter++;
if (m_counter == 6) m_btnAddView.setEnabled(false);
}
if (null != sourceImage.getBackground())
{
//imageview have image
testImage = sourceImage;
Log.d(TAG, "Image is not null in addView");
}
else
{
//imageview have no image
Log.d(TAG, "Image is null");
}

// sourceImage.setOnTouchListener(m_onTouchListener);
targetImage.setOnTouchListener(m_onTouchListener);
sourceImage.setOnTouchListener(m_onTouchListener);
m_tv.setOnTouchListener(m_onTouchListener);
}

public void removeView()
{
m_counter = 0;
m_alTop.removeAllViews();
m_alTop.invalidate();
m_btnAddView.setEnabled(true);
}

@Override
public void onBackPressed()
{
this.clearView();
super.onBackPressed();
}

@Override
protected void onDestroy()
{
this.clearView();
super.onDestroy();
}

/**
* Clear the views and free memory
*/
public void clearView()
{
if (m_context != null) m_context = null;

if (m_llTop != null) m_llTop = null;

if (m_alTop != null) m_alTop = null;

if (m_btnAddView != null) m_btnAddView = null;

if (m_btnRemove != null) m_btnRemove = null;

if (m_ivImage1 != null) m_ivImage1 = null;
}

@Override
public boolean onDrag(View view, DragEvent dragEvent)
{
Log.d(TAG, "Drop Event " + dragEvent.getAction());
return true;
}

这段代码的输出:

如您所见,Droid 上方有一颗星星。但是现在如何从中制作图像并按原样保存?

最佳答案

此函数将 View 转换为位图。将目标图像传递给以下方法,将返回其所有 subview 的位图。

public static Bitmap getBitmapFromView(View view) {
//Define a bitmap with the same size as the view
Bitmap returnedBitmap = Bitmap.createBitmap(view.getWidth(), view.getHeight(),Bitmap.Config.ARGB_8888);
//Bind a canvas to it
Canvas canvas = new Canvas(returnedBitmap);
//Get the view's background
Drawable bgDrawable =view.getBackground();
if (bgDrawable!=null)
//has background drawable, then draw it on the canvas
bgDrawable.draw(canvas);
else
//does not have background drawable, then draw white background on the canvas
canvas.drawColor(Color.WHITE);
// draw the view on the canvas
view.draw(canvas);
//return the bitmap
return returnedBitmap;
}

关于android - 如何在覆盖其他图像后合并/保存图像?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29624446/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com