我使用下面的code。而我现在的储蓄。我是能够拯救位图图像,但是当保存BIMAP这也节省了我删去了也画有黑色
当越来越问题 公共类FingerPaint扩展GraphicsActivity
实现ColorPickerDialog.OnColorChangedListener {
@覆盖
保护无效的onCreate(包savedInstanceState){
super.onCreate(savedInstanceState);
的setContentView(新MyView的(这个));
mPaint =新的油漆();
mPaint.setAntiAlias(真正的);
mPaint.setDither(真正的);
mPaint.setColor(0xFFFF0000地址);
mPaint.setStyle(Paint.Style.STROKE);
mPaint.setStrokeJoin(Paint.Join.ROUND);
mPaint.setStrokeCap(Paint.Cap.ROUND);
mPaint.setStrokeWidth(12);
mEmboss =新EmbossMaskFilter(新浮法[] {1,1,1},
0.4f,6,3.5F);
运动模糊=新BlurMaskFilter(8,BlurMaskFilter.Blur.NORMAL);
}
私人油漆mPaint;
私人MaskFilter将mEmboss;
私人MaskFilter将运动模糊;
公共无效colorChanged(INT颜色){
mPaint.setColor(颜色);
}
公共类MyView的扩展视图{
私有静态最终浮动MINP = 0.25f;
私有静态最终浮动MAXP = 0.75f;
私人位图mBitmap;
私人帆布mCanvas;
私人路径的mpath;
私人油漆mBitmapPaint;
公共MyView的(语境C){
超级(C);
mBitmap = Bitmap.createBitmap(320,480,Bitmap.Config.ARGB_8888);
mCanvas =新的Canvas(mBitmap);
的mpath =新路径();
mBitmapPaint =新的油漆(Paint.DITHER_FLAG);
}
@覆盖
保护无效onSizeChanged(INT W,INT小时,INT oldw,诠释oldh){
super.onSizeChanged(W,H,oldw,oldh);
}
@覆盖
保护无效的OnDraw(帆布油画){
canvas.drawColor(0xFFAAAAAA);
canvas.drawBitmap(mBitmap,0,0,mBitmapPaint);
canvas.drawPath(的mpath,mPaint);
}
私人浮动MX,我的;
私有静态最终浮动TOUCH_TOLERANCE = 4;
私人无效touch_start(浮X,浮动Y){
mPath.reset();
mPath.moveTo(X,Y);
MX = X;
我= Y;
}
私人无效TOUCH_MOVE(浮X,浮动Y){
浮DX = Math.abs(X - MX);
浮DY = Math.abs(Y - 我的);
如果(DX> = TOUCH_TOLERANCE || DY> = TOUCH_TOLERANCE){
mPath.quadTo(MX,MY,(X + MX)/ 2,(Y +我)/ 2);
MX = X;
我= Y;
}
}
私人无效touch_up(){
mPath.lineTo(MX,MY);
//提交路径,我们的屏幕外
mCanvas.drawPath(的mpath,mPaint);
//杀了这个,所以我们不重复抽奖
mPath.reset();
}
@覆盖
公共布尔的onTouchEvent(MotionEvent事件){
浮X = event.getX();
浮动Y = event.getY();
开关(event.getAction()){
案例MotionEvent.ACTION_DOWN:
touch_start(X,Y);
无效();
打破;
案例MotionEvent.ACTION_MOVE:
TOUCH_MOVE(X,Y);
无效();
打破;
案例MotionEvent.ACTION_UP:
润色();
无效();
打破;
}
返回true;
}
}
私有静态最终诠释COLOR_MENU_ID = Menu.FIRST;
私有静态最终诠释EMBOSS_MENU_ID = Menu.FIRST + 1;
私有静态最终诠释BLUR_MENU_ID = Menu.FIRST + 2;
私有静态最终诠释ERASE_MENU_ID = Menu.FIRST + 3;
私有静态最终诠释SRCATOP_MENU_ID = Menu.FIRST + 4;
@覆盖
公共布尔onCreateOptionsMenu(功能菜单){
super.onCreateOptionsMenu(菜单);
menu.add(0,COLOR_MENU_ID,0,颜色)setShortcut('3','c')中。
menu.add(0,EMBOSS_MENU_ID,0,浮雕)setShortcut('4','s'的)。
menu.add(0,BLUR_MENU_ID,0,模糊)setShortcut('5','Z')。
menu.add(0,ERASE_MENU_ID,0,擦除)setShortcut('5','Z')。
menu.add(0,SRCATOP_MENU_ID,0,SrcATop)setShortcut('5','Z')。
/ ****这是该机制与滤镜效果延伸?
意向意图=新的意图(空,getIntent()的getData());
intent.addCategory(Intent.CATEGORY_ALTERNATIVE);
menu.addIntentOptions(
Menu.ALTERNATIVE,0,
新的组件名(本,NotesList.class)
空,意向,0,NULL);
***** /
返回true;
}
@覆盖
公共布尔prepareOptionsMenu(功能菜单)在{
super.on prepareOptionsMenu(菜单);
返回true;
}
@覆盖
公共布尔onOptionsItemSelected(菜单项项){
mPaint.setXfermode(空);
mPaint.setAlpha(0xFF的);
开关(item.getItemId()){
案例COLOR_MENU_ID:
新ColorPickerDialog(这个,这个,mPaint.getColor())显示()。
返回true;
案例EMBOSS_MENU_ID:
如果(mPaint.getMaskFilter()!= mEmboss){
mPaint.setMaskFilter(mEmboss);
} 其他 {
mPaint.setMaskFilter(空);
}
返回true;
案例BLUR_MENU_ID:
如果(mPaint.getMaskFilter()!=运动模糊){
mPaint.setMaskFilter(运动模糊);
} 其他 {
mPaint.setMaskFilter(空);
}
返回true;
案例ERASE_MENU_ID:
mPaint.setXfermode(新PorterDuffXfermode(
PorterDuff.Mode.CLEAR));
返回true;
案例SRCATOP_MENU_ID:
mPaint.setXfermode(新PorterDuffXfermode(
PorterDuff.Mode.SRC_ATOP));
mPaint.setAlpha(0x80的);
返回true;
}
返回super.onOptionsItemSelected(项目);
}
}
解决方案
我做了一些改变你的code和它的作品。我还添加了一个保存选项。
公共类FingerPaintActivity扩展GraphicsActivity实现ColorPickerDialog.OnColorChangedListener {
MyView的MV;
@覆盖
保护无效的onCreate(包savedInstanceState){
super.onCreate(savedInstanceState);
MV =新的MyView的(这一点);
mv.setDrawingCacheEnabled(真正的);
的setContentView(MV);
mPaint =新的油漆();
mPaint.setAntiAlias(真正的);
mPaint.setDither(真正的);
mPaint.setColor(0xFFFF0000地址);
mPaint.setStyle(Paint.Style.STROKE);
mPaint.setStrokeJoin(Paint.Join.ROUND);
mPaint.setStrokeCap(Paint.Cap.ROUND);
mPaint.setStrokeWidth(12);
mEmboss =新EmbossMaskFilter(新浮法[] {1,1,1},
0.4f,6,3.5F);
运动模糊=新BlurMaskFilter(8,BlurMaskFilter.Blur.NORMAL);
}
私人油漆mPaint;
私人MaskFilter将mEmboss;
私人MaskFilter将运动模糊;
公共无效colorChanged(INT颜色){
mPaint.setColor(颜色);
}
公共类MyView的扩展视图{
私有静态最终浮动MINP = 0.25f;
私有静态最终浮动MAXP = 0.75f;
私人位图mBitmap;
私人帆布mCanvas;
私人路径的mpath;
私人油漆mBitmapPaint;
上下文语境;
公共MyView的(语境C){
超级(C);
上下文= C;
// mBitmap = Bitmap.createBitmap(320,480,Bitmap.Config.ARGB_8888);
的mpath =新路径();
mBitmapPaint =新的油漆(Paint.DITHER_FLAG);
}
@覆盖
保护无效onSizeChanged(INT W,INT小时,INT oldw,诠释oldh){
super.onSizeChanged(W,H,oldw,oldh);
mBitmap = Bitmap.createBitmap(W,H,Bitmap.Config.ARGB_8888);
mCanvas =新的Canvas(mBitmap);
}
@覆盖
保护无效的OnDraw(帆布油画){
canvas.drawColor(0xFFAAAAAA);
canvas.drawBitmap(mBitmap,0,0,mBitmapPaint);
canvas.drawPath(的mpath,mPaint);
}
私人浮动MX,我的;
私有静态最终浮动TOUCH_TOLERANCE = 4;
私人无效touch_start(浮X,浮动Y){
mPath.reset();
mPath.moveTo(X,Y);
MX = X;
我= Y;
}
私人无效TOUCH_MOVE(浮X,浮动Y){
浮DX = Math.abs(X - MX);
浮DY = Math.abs(Y - 我的);
如果(DX> = TOUCH_TOLERANCE || DY> = TOUCH_TOLERANCE){
mPath.quadTo(MX,MY,(X + MX)/ 2,(Y +我)/ 2);
MX = X;
我= Y;
}
}
私人无效touch_up(){
mPath.lineTo(MX,MY);
//提交路径,我们的屏幕外
mCanvas.drawPath(的mpath,mPaint);
//杀了这个,所以我们不重复抽奖
mPath.reset();
mPaint.setXfermode(新PorterDuffXfermode(PorterDuff.Mode.SCREEN));
mPaint.setMaskFilter(空);
}
@覆盖
公共布尔的onTouchEvent(MotionEvent事件){
浮X = event.getX();
浮动Y = event.getY();
开关(event.getAction()){
案例MotionEvent.ACTION_DOWN:
touch_start(X,Y);
无效();
打破;
案例MotionEvent.ACTION_MOVE:
TOUCH_MOVE(X,Y);
无效();
打破;
案例MotionEvent.ACTION_UP:
润色();
无效();
打破;
}
返回true;
}
}
私有静态最终诠释COLOR_MENU_ID = Menu.FIRST;
私有静态最终诠释EMBOSS_MENU_ID = Menu.FIRST + 1;
私有静态最终诠释BLUR_MENU_ID = Menu.FIRST + 2;
私有静态最终诠释ERASE_MENU_ID = Menu.FIRST + 3;
私有静态最终诠释SRCATOP_MENU_ID = Menu.FIRST + 4;
私有静态最终诠释保存= Menu.FIRST + 5;
@覆盖
公共布尔onCreateOptionsMenu(功能菜单){
super.onCreateOptionsMenu(菜单);
menu.add(0,COLOR_MENU_ID,0,颜色)setShortcut('3','c')中。
menu.add(0,EMBOSS_MENU_ID,0,浮雕)setShortcut('4','s'的)。
menu.add(0,BLUR_MENU_ID,0,模糊)setShortcut('5','Z')。
menu.add(0,ERASE_MENU_ID,0,擦除)setShortcut('5','Z')。
menu.add(0,SRCATOP_MENU_ID,0,SrcATop)setShortcut('5','Z')。
menu.add(0,保存,0,保存)setShortcut('5','Z')。
/ ****这是该机制与滤镜效果延伸?
意向意图=新的意图(空,getIntent()的getData());
intent.addCategory(Intent.CATEGORY_ALTERNATIVE);
menu.addIntentOptions(
Menu.ALTERNATIVE,0,
新的组件名(本,NotesList.class)
空,意向,0,NULL);
***** /
返回true;
}
@覆盖
公共布尔prepareOptionsMenu(功能菜单)在{
super.on prepareOptionsMenu(菜单);
返回true;
}
@覆盖
公共布尔onOptionsItemSelected(菜单项项){
mPaint.setXfermode(空);
mPaint.setAlpha(0xFF的);
开关(item.getItemId()){
案例COLOR_MENU_ID:
新ColorPickerDialog(这个,这个,mPaint.getColor())显示()。
返回true;
案例EMBOSS_MENU_ID:
如果(mPaint.getMaskFilter()!= mEmboss){
mPaint.setMaskFilter(mEmboss);
} 其他 {
mPaint.setMaskFilter(空);
}
返回true;
案例BLUR_MENU_ID:
如果(mPaint.getMaskFilter()!=运动模糊){
mPaint.setMaskFilter(运动模糊);
} 其他 {
mPaint.setMaskFilter(空);
}
返回true;
案例ERASE_MENU_ID:
mPaint.setXfermode(新PorterDuffXfermode(
PorterDuff.Mode.CLEAR));
返回true;
案例SRCATOP_MENU_ID:
mPaint.setXfermode(新PorterDuffXfermode(
PorterDuff.Mode.SRC_ATOP));
mPaint.setAlpha(0x80的);
返回true;
情况下节省:
AlertDialog.Builder editalert =新AlertDialog.Builder(FingerPaintActivity.this);
editalert.setTitle(请输入与您要保存的名字);
最后的EditText输入=新的EditText(FingerPaintActivity.this);
LinearLayout.LayoutParams LP =新LinearLayout.LayoutParams(
LinearLayout.LayoutParams.FILL_PARENT,
LinearLayout.LayoutParams.FILL_PARENT);
input.setLayoutParams(LP);
editalert.setView(输入);
editalert.setPositiveButton(OK,新DialogInterface.OnClickListener(){
公共无效的onClick(DialogInterface对话,诠释whichButton){
字符串名称= input.getText()的toString()。
点阵位图= mv.getDrawingCache();
字符串路径= Environment.getExternalStorageDirectory()getAbsolutePath()。
档案文件=新的文件(/ SD卡/+姓名+PNG);
尝试
{
如果(!file.exists())
{
file.createNewFile();
}
FileOutputStream中的ostream =新的FileOutputStream(文件);
bitmap.com preSS(比较pressFormat.PNG,10,ostream的);
的System.out.println(节约.......................................... ............+路径);
ostream.close();
mv.invalidate();
}
赶上(例外五)
{
e.printStackTrace();
}最后
{
mv.setDrawingCacheEnabled(假);
}
}
});
editalert.show();
返回true;
}
返回super.onOptionsItemSelected(项目);
}
}
编辑:
@覆盖
保护无效onSizeChanged(INT W,INT小时,INT oldw,诠释oldh){
super.onSizeChanged(W,H,oldw,oldh);
mBitmap = Bitmap.createBitmap(W,H,Bitmap.Config.ARGB_8888);
mCanvas =新的Canvas(mBitmap);
BMP位= BitmapFactory.de codeResource(getResources(),R.drawable.afor);
mCanvas.drawBitmap(BMP,0,0,mPaint);
}
I am using following code . and i am getting problem when saving images .i am able to save bitmap but when save bimap it saves also i erased paint also with black color
public class FingerPaint extends GraphicsActivity
implements ColorPickerDialog.OnColorChangedListener {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(new MyView(this));
mPaint = new Paint();
mPaint.setAntiAlias(true);
mPaint.setDither(true);
mPaint.setColor(0xFFFF0000);
mPaint.setStyle(Paint.Style.STROKE);
mPaint.setStrokeJoin(Paint.Join.ROUND);
mPaint.setStrokeCap(Paint.Cap.ROUND);
mPaint.setStrokeWidth(12);
mEmboss = new EmbossMaskFilter(new float[] { 1, 1, 1 },
0.4f, 6, 3.5f);
mBlur = new BlurMaskFilter(8, BlurMaskFilter.Blur.NORMAL);
}
private Paint mPaint;
private MaskFilter mEmboss;
private MaskFilter mBlur;
public void colorChanged(int color) {
mPaint.setColor(color);
}
public class MyView extends View {
private static final float MINP = 0.25f;
private static final float MAXP = 0.75f;
private Bitmap mBitmap;
private Canvas mCanvas;
private Path mPath;
private Paint mBitmapPaint;
public MyView(Context c) {
super(c);
mBitmap = Bitmap.createBitmap(320, 480, Bitmap.Config.ARGB_8888);
mCanvas = new Canvas(mBitmap);
mPath = new Path();
mBitmapPaint = new Paint(Paint.DITHER_FLAG);
}
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
super.onSizeChanged(w, h, oldw, oldh);
}
@Override
protected void onDraw(Canvas canvas) {
canvas.drawColor(0xFFAAAAAA);
canvas.drawBitmap(mBitmap, 0, 0, mBitmapPaint);
canvas.drawPath(mPath, mPaint);
}
private float mX, mY;
private static final float TOUCH_TOLERANCE = 4;
private void touch_start(float x, float y) {
mPath.reset();
mPath.moveTo(x, y);
mX = x;
mY = y;
}
private void touch_move(float x, float y) {
float dx = Math.abs(x - mX);
float dy = Math.abs(y - mY);
if (dx >= TOUCH_TOLERANCE || dy >= TOUCH_TOLERANCE) {
mPath.quadTo(mX, mY, (x + mX)/2, (y + mY)/2);
mX = x;
mY = y;
}
}
private void touch_up() {
mPath.lineTo(mX, mY);
// commit the path to our offscreen
mCanvas.drawPath(mPath, mPaint);
// kill this so we don't double draw
mPath.reset();
}
@Override
public boolean onTouchEvent(MotionEvent event) {
float x = event.getX();
float y = event.getY();
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
touch_start(x, y);
invalidate();
break;
case MotionEvent.ACTION_MOVE:
touch_move(x, y);
invalidate();
break;
case MotionEvent.ACTION_UP:
touch_up();
invalidate();
break;
}
return true;
}
}
private static final int COLOR_MENU_ID = Menu.FIRST;
private static final int EMBOSS_MENU_ID = Menu.FIRST + 1;
private static final int BLUR_MENU_ID = Menu.FIRST + 2;
private static final int ERASE_MENU_ID = Menu.FIRST + 3;
private static final int SRCATOP_MENU_ID = Menu.FIRST + 4;
@Override
public boolean onCreateOptionsMenu(Menu menu) {
super.onCreateOptionsMenu(menu);
menu.add(0, COLOR_MENU_ID, 0, "Color").setShortcut('3', 'c');
menu.add(0, EMBOSS_MENU_ID, 0, "Emboss").setShortcut('4', 's');
menu.add(0, BLUR_MENU_ID, 0, "Blur").setShortcut('5', 'z');
menu.add(0, ERASE_MENU_ID, 0, "Erase").setShortcut('5', 'z');
menu.add(0, SRCATOP_MENU_ID, 0, "SrcATop").setShortcut('5', 'z');
/**** Is this the mechanism to extend with filter effects?
Intent intent = new Intent(null, getIntent().getData());
intent.addCategory(Intent.CATEGORY_ALTERNATIVE);
menu.addIntentOptions(
Menu.ALTERNATIVE, 0,
new ComponentName(this, NotesList.class),
null, intent, 0, null);
*****/
return true;
}
@Override
public boolean onPrepareOptionsMenu(Menu menu) {
super.onPrepareOptionsMenu(menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
mPaint.setXfermode(null);
mPaint.setAlpha(0xFF);
switch (item.getItemId()) {
case COLOR_MENU_ID:
new ColorPickerDialog(this, this, mPaint.getColor()).show();
return true;
case EMBOSS_MENU_ID:
if (mPaint.getMaskFilter() != mEmboss) {
mPaint.setMaskFilter(mEmboss);
} else {
mPaint.setMaskFilter(null);
}
return true;
case BLUR_MENU_ID:
if (mPaint.getMaskFilter() != mBlur) {
mPaint.setMaskFilter(mBlur);
} else {
mPaint.setMaskFilter(null);
}
return true;
case ERASE_MENU_ID:
mPaint.setXfermode(new PorterDuffXfermode(
PorterDuff.Mode.CLEAR));
return true;
case SRCATOP_MENU_ID:
mPaint.setXfermode(new PorterDuffXfermode(
PorterDuff.Mode.SRC_ATOP));
mPaint.setAlpha(0x80);
return true;
}
return super.onOptionsItemSelected(item);
}
}
解决方案
I made a few changes to your code and it works. I also added a save option.
public class FingerPaintActivity extends GraphicsActivity implements ColorPickerDialog.OnColorChangedListener {
MyView mv;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mv= new MyView(this);
mv.setDrawingCacheEnabled(true);
setContentView(mv);
mPaint = new Paint();
mPaint.setAntiAlias(true);
mPaint.setDither(true);
mPaint.setColor(0xFFFF0000);
mPaint.setStyle(Paint.Style.STROKE);
mPaint.setStrokeJoin(Paint.Join.ROUND);
mPaint.setStrokeCap(Paint.Cap.ROUND);
mPaint.setStrokeWidth(12);
mEmboss = new EmbossMaskFilter(new float[] { 1, 1, 1 },
0.4f, 6, 3.5f);
mBlur = new BlurMaskFilter(8, BlurMaskFilter.Blur.NORMAL);
}
private Paint mPaint;
private MaskFilter mEmboss;
private MaskFilter mBlur;
public void colorChanged(int color) {
mPaint.setColor(color);
}
public class MyView extends View {
private static final float MINP = 0.25f;
private static final float MAXP = 0.75f;
private Bitmap mBitmap;
private Canvas mCanvas;
private Path mPath;
private Paint mBitmapPaint;
Context context;
public MyView(Context c) {
super(c);
context=c;
//mBitmap = Bitmap.createBitmap(320, 480, Bitmap.Config.ARGB_8888);
mPath = new Path();
mBitmapPaint = new Paint(Paint.DITHER_FLAG);
}
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
super.onSizeChanged(w, h, oldw, oldh);
mBitmap = Bitmap.createBitmap(w, h, Bitmap.Config.ARGB_8888);
mCanvas = new Canvas(mBitmap);
}
@Override
protected void onDraw(Canvas canvas) {
canvas.drawColor(0xFFAAAAAA);
canvas.drawBitmap(mBitmap, 0, 0, mBitmapPaint);
canvas.drawPath(mPath, mPaint);
}
private float mX, mY;
private static final float TOUCH_TOLERANCE = 4;
private void touch_start(float x, float y) {
mPath.reset();
mPath.moveTo(x, y);
mX = x;
mY = y;
}
private void touch_move(float x, float y) {
float dx = Math.abs(x - mX);
float dy = Math.abs(y - mY);
if (dx >= TOUCH_TOLERANCE || dy >= TOUCH_TOLERANCE) {
mPath.quadTo(mX, mY, (x + mX)/2, (y + mY)/2);
mX = x;
mY = y;
}
}
private void touch_up() {
mPath.lineTo(mX, mY);
// commit the path to our offscreen
mCanvas.drawPath(mPath, mPaint);
// kill this so we don't double draw
mPath.reset();
mPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SCREEN));
mPaint.setMaskFilter(null);
}
@Override
public boolean onTouchEvent(MotionEvent event) {
float x = event.getX();
float y = event.getY();
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
touch_start(x, y);
invalidate();
break;
case MotionEvent.ACTION_MOVE:
touch_move(x, y);
invalidate();
break;
case MotionEvent.ACTION_UP:
touch_up();
invalidate();
break;
}
return true;
}
}
private static final int COLOR_MENU_ID = Menu.FIRST;
private static final int EMBOSS_MENU_ID = Menu.FIRST + 1;
private static final int BLUR_MENU_ID = Menu.FIRST + 2;
private static final int ERASE_MENU_ID = Menu.FIRST + 3;
private static final int SRCATOP_MENU_ID = Menu.FIRST + 4;
private static final int Save = Menu.FIRST + 5;
@Override
public boolean onCreateOptionsMenu(Menu menu) {
super.onCreateOptionsMenu(menu);
menu.add(0, COLOR_MENU_ID, 0, "Color").setShortcut('3', 'c');
menu.add(0, EMBOSS_MENU_ID, 0, "Emboss").setShortcut('4', 's');
menu.add(0, BLUR_MENU_ID, 0, "Blur").setShortcut('5', 'z');
menu.add(0, ERASE_MENU_ID, 0, "Erase").setShortcut('5', 'z');
menu.add(0, SRCATOP_MENU_ID, 0, "SrcATop").setShortcut('5', 'z');
menu.add(0, Save, 0, "Save").setShortcut('5', 'z');
/**** Is this the mechanism to extend with filter effects?
Intent intent = new Intent(null, getIntent().getData());
intent.addCategory(Intent.CATEGORY_ALTERNATIVE);
menu.addIntentOptions(
Menu.ALTERNATIVE, 0,
new ComponentName(this, NotesList.class),
null, intent, 0, null);
*****/
return true;
}
@Override
public boolean onPrepareOptionsMenu(Menu menu) {
super.onPrepareOptionsMenu(menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
mPaint.setXfermode(null);
mPaint.setAlpha(0xFF);
switch (item.getItemId()) {
case COLOR_MENU_ID:
new ColorPickerDialog(this, this, mPaint.getColor()).show();
return true;
case EMBOSS_MENU_ID:
if (mPaint.getMaskFilter() != mEmboss) {
mPaint.setMaskFilter(mEmboss);
} else {
mPaint.setMaskFilter(null);
}
return true;
case BLUR_MENU_ID:
if (mPaint.getMaskFilter() != mBlur) {
mPaint.setMaskFilter(mBlur);
} else {
mPaint.setMaskFilter(null);
}
return true;
case ERASE_MENU_ID:
mPaint.setXfermode(new PorterDuffXfermode(
PorterDuff.Mode.CLEAR));
return true;
case SRCATOP_MENU_ID:
mPaint.setXfermode(new PorterDuffXfermode(
PorterDuff.Mode.SRC_ATOP));
mPaint.setAlpha(0x80);
return true;
case Save:
AlertDialog.Builder editalert = new AlertDialog.Builder(FingerPaintActivity.this);
editalert.setTitle("Please Enter the name with which you want to Save");
final EditText input = new EditText(FingerPaintActivity.this);
LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.FILL_PARENT,
LinearLayout.LayoutParams.FILL_PARENT);
input.setLayoutParams(lp);
editalert.setView(input);
editalert.setPositiveButton("OK", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int whichButton) {
String name= input.getText().toString();
Bitmap bitmap = mv.getDrawingCache();
String path = Environment.getExternalStorageDirectory().getAbsolutePath();
File file = new File("/sdcard/"+name+".png");
try
{
if(!file.exists())
{
file.createNewFile();
}
FileOutputStream ostream = new FileOutputStream(file);
bitmap.compress(CompressFormat.PNG, 10, ostream);
System.out.println("saving......................................................"+path);
ostream.close();
mv.invalidate();
}
catch (Exception e)
{
e.printStackTrace();
}finally
{
mv.setDrawingCacheEnabled(false);
}
}
});
editalert.show();
return true;
}
return super.onOptionsItemSelected(item);
}
}
Edit :
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
super.onSizeChanged(w, h, oldw, oldh);
mBitmap = Bitmap.createBitmap(w, h, Bitmap.Config.ARGB_8888);
mCanvas = new Canvas(mBitmap);
Bitmap bmp = BitmapFactory.decodeResource(getResources(), R.drawable.afor);
mCanvas.drawBitmap(bmp, 0, 0, mPaint);
}