質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.96%

SurfaceViewを保存、表示したい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 2,854

KanPiko

score 12

前提・実現したいこと

Android studioでSurfaceViewを保存、表示を行いたいのですがどのようにプログラムしたらいいのかわかりません。

該当のソースコード

SurfaceView を継承して絵を描画するクラス です。

public class DrawSurfaceView extends SurfaceView implements Callback{

    private SurfaceHolder mHolder;
    private Paint mPaint;
    private Path mPath;
    private Bitmap mLastDrawBitmap;
    private Canvas mLastDrawCanvas;
    private Deque<Path> mUndoStack = new ArrayDeque<Path>();
    private Deque<Path> mRedoStack = new ArrayDeque<Path>();

    SharedPreferences pref;
    public DrawSurfaceView(Context context) {
        super(context);
        init();
    }
    public DrawSurfaceView(Context context, AttributeSet attrs) {
        super(context, attrs);
        init();
    }

    private void init() {
        mHolder = getHolder();
        setZOrderOnTop(true);
        mHolder.setFormat(PixelFormat.TRANSPARENT); 
        mHolder.addCallback(this);
        // ペイントを設定
        mPaint = new Paint();
        mPaint.setColor(Color.BLACK);
        mPaint.setStyle(Paint.Style.STROKE);
        mPaint.setStrokeCap(Paint.Cap.ROUND);
        mPaint.setAntiAlias(true);
        mPaint.setStrokeWidth(20);
    }

    @Override
    public void surfaceCreated(SurfaceHolder holder) {
        clearLastDrawBitmap();
    }

    @Override
    public void surfaceChanged(SurfaceHolder holder, int format, int width,
                               int height) {
    }
    @Override
    public void surfaceDestroyed(SurfaceHolder holder) {
        mLastDrawBitmap.recycle();
    }
    private void clearLastDrawBitmap() {
        if (mLastDrawBitmap == null) {
            mLastDrawBitmap = Bitmap.createBitmap(getWidth(), getHeight(),
                    Config.ARGB_8888);
        }
      if (mLastDrawCanvas == null) {
            mLastDrawCanvas = new Canvas(mLastDrawBitmap);
        }
        mLastDrawCanvas.drawColor(0, Mode.CLEAR);
    }
    @Override
    public boolean onTouchEvent(MotionEvent event) {
        switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN:
                onTouchDown(event.getX(), event.getY());
                break;
            case MotionEvent.ACTION_MOVE:
                onTouchMove(event.getX(), event.getY());
                break;
            case MotionEvent.ACTION_UP:
                onTouchUp(event.getX(), event.getY());
                break;
            default:
        }
        return true;
    }

    private void onTouchDown(float x, float y) {
        mPath = new Path();
        mPath.moveTo(x, y);
    }

    private void onTouchMove(float x, float y) {
        mPath.lineTo(x, y);
        drawLine(mPath);
    }

    private void onTouchUp(float x, float y) {
        mPath.lineTo(x, y);
        drawLine(mPath);
        mLastDrawCanvas.drawPath(mPath, mPaint);
        mUndoStack.addLast(mPath);
        mRedoStack.clear();
    }

    private void drawLine(Path path) {
        // ロックしてキャンバスを取得
        Canvas canvas = mHolder.lockCanvas();
        // キャンバスをクリア
        canvas.drawColor(0, Mode.CLEAR);
        // 前回描画したビットマップをキャンバスに描画
        canvas.drawBitmap(mLastDrawBitmap, 0, 0, null);
        // パスを描画
        canvas.drawPath(path, mPaint);

        mHolder.unlockCanvasAndPost(canvas);

    }
    public void reset() {//リセット
        mUndoStack.clear();
        mRedoStack.clear();
        clearLastDrawBitmap();
        Canvas canvas = mHolder.lockCanvas();
        canvas.drawColor(0, Mode.CLEAR);
        mHolder.unlockCanvasAndPost(canvas);
    }
}

以下のプログラムのSurfaceView1を保存したいです。

public class Problem1Activity extends FragmentActivity implements OnClickListener  {
    private DrawSurfaceView SurfaceView1;
    private Button reset1;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_problem1);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);


        FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                        .setAction("Action", null).show();
            }
        });
        SurfaceView1 =(DrawSurfaceView) findViewById(R.id.surfaceView1);

        reset1=(Button)findViewById(R.id.reset1);
        reset1.setOnClickListener(this);
    }
    @Override
    public  void onClick(View v){
        if(v==reset1){
            SurfaceView1.reset();
        }
    }
    public void buttonClick1(View view){
        SurfaceView1.setDrawingCacheEnabled(true);//
        Intent intent = new Intent(this,Problem1_g_Activity.class);
        startActivity(intent);
    }

}

保存したSurfaceView1をここに表示したいです。

public class Problem1_s_Activity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_problem1_s_);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

        FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                        .setAction("Action", null).show();
  }
        });
    }
    public void onReturn1(View view){
        Intent intent= new Intent(this,Main2Activity.class);
        startActivity(intent);
    }

}
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • swordone

    2017/04/02 09:10

    SurfaceViewを「保存」というのが意味がわかりません。

    キャンセル

  • uniko

    2017/04/02 09:16

    もしかしてアプリ内(SurfaceView)のスクリーンショットが撮りたいみたいな事ですか?

    キャンセル

  • KanPiko

    2017/04/02 11:46

    今、SurfaceViewで絵を描画できる状態なので、最後に描画したものを別のActivityで表示させたいんです。スクリーンショットでも表示できるのであれば教えてほしいです。

    キャンセル

回答 1

checkベストアンサー

0

SurfaceViewからBitmapに落としてやればどうですか?

Bitmap bitmap = Bitmap.createBitmap(view.getWidth(),view.getHeight(),Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
view.draw(canvas);

どうやらSurfaceViewだとキャプチャーできないようですね。
上の回答は無視してください。申し訳ないです。

ただ今回でいうとDrawSurfaceView内でmLastDrawBitmapが描画を持っている様なのでそちらを使えばいけるかと思います。なお、一応TextureViewというのもあるのですがそちらだとgetBitmapで取れるので要件によってはこちらもありかもです。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/04/02 17:16

    一応回答を編集しました。別画面に関しては遷移先にstartActivityするIntentに入れたりやファイルに一回落とすなりやり方は色々あるかと思います。サイト内の質問にもあるやもしれませんので参照してみてくださいませ。

    キャンセル

  • 2017/04/02 18:10

    詳しく説明していただきありがとうございました。
    TextureViewも一度使ってみたりしていろいろ試してみたいと思います。

    キャンセル

  • 2017/04/02 18:18

    いえ、こちらこそあまり力になれず申し訳ないです。調べたところSurfaceViewの場合はdrow時の処理を一時的に別のcanvasに変えたりして対応していたりなど何かしら工夫してるようです。一応記載しておきます。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.96%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる