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

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

ただいまの
回答率

88.20%

android 手書きメモ カラーパレットの付け方

解決済

回答 2

投稿

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

naocchoro

score 10

専門学校の授業で班ごとにアプリ開発をしています。
そのアプリの中でも手書きメモを作ってるのですが白黒メモだとうまくいくのですがカラーパレットの付け方がわかりません。
単にタップしてる座標に黒い色をつける動作とは違い、複数の色を管理する方法を教えて下さい。
また画像の保存がうまくいきません。保存ボタンを押しても保存されないのです。
初歩的な質問で大変申し訳無いと思いますがよろしくお願いします。
環境はandroid studio
mac osx 10.11.2
言語は日本語です。
今現在のcodeを貼ります。

import android.app.Activity;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Bitmap.CompressFormat;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Point;
import android.os.Bundle;
import android.os.Environment;
import android.view.Menu;
import android.view.MenuItem;
import android.view.MotionEvent;
import java.io.File;
import java.io.FileOutputStream;
import java.util.Date;

/ メインクラスの定義 */
public class Main3Activity extends Activity {
    DrawNoteView view;
    private static final int MENU_CLEAR = 0;
    private static final int MENU_SAVE = 1;
    /
 アプリの初期化 */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // 描画クラスを設定
        view = new DrawNoteView(getApplication());
        setContentView(view);
    }
    / メニューの生成イベント */
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        super.onCreateOptionsMenu(menu);
        menu.add(0, MENU_CLEAR, 0, "Clear");
        menu.add(0, MENU_SAVE, 0, "Save");
        return true;
    }
    /
 メニューがクリックされた時のイベント */
    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        switch ( item.getItemId() ) {
            case MENU_CLEAR:
                view.clearDrawList(); break;
            case MENU_SAVE:
                view.saveToFile();
                break;
        }
        return true;
    }
}
/ 描画クラスの定義 */
class DrawNoteView extends android.view.View {
    Bitmap bmp = null;
    Canvas bmpCanvas;
    Point oldpos = new Point(-1,-1);
    public DrawNoteView(Context c) {
        super(c);
        setFocusable(true);
    }
    public void clearDrawList() {
        bmpCanvas.drawColor(Color.WHITE);
        invalidate();
    }
    public void saveToFile() {
        // 保存先の決定
        String status = Environment.getExternalStorageState();
        File fout;
        if (!status.equals(Environment.MEDIA_MOUNTED)) {
            fout = Environment.getDataDirectory();
        } else {
            fout = new File("/sdcard/DrawNoteK/");
            fout.mkdirs();
        }
        Date d = new Date();
        String fname = fout.getAbsolutePath() + "/";
        fname += String.format("%4d%02d%02d-%02d%02d%02d.png",
                (1900+d.getYear()), d.getMonth(), d.getDate(),
                d.getHours(), d.getMinutes(), d.getSeconds());
        // 画像をファイルに書き込む
        try {
            FileOutputStream out = new FileOutputStream(fname);
            bmp.compress(CompressFormat.JPEG, 100, out);
            out.flush(); out.close();
        } catch(Exception e) {}
    }
    /
 画面サイズが変更された時 */
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {
        super.onSizeChanged(w,h,oldw,oldh);
        bmp = Bitmap.createBitmap(w, h, Bitmap.Config.ARGB_8888);
        bmpCanvas = new Canvas(bmp);
        bmpCanvas.drawColor(Color.WHITE);
    }
    / 描画イベント */
    protected void onDraw(Canvas canvas) {
        canvas.drawBitmap(bmp, 0, 0, null);
    }
    /
 タッチイベント */
    public boolean onTouchEvent(MotionEvent event) {
        // 描画位置の確認
        Point cur = new Point((int)event.getX(), (int)event.getY());
        if (oldpos.x < 0) { oldpos = cur; }
        // 描画属性を設定
        Paint paint = new Paint();
        paint.setColor(Color.BLACK);
        paint.setStyle(Paint.Style.FILL);
        paint.setStrokeWidth(7);
        // 線を描画
        bmpCanvas.drawLine(oldpos.x, oldpos.y, cur.x, cur.y, paint);
        oldpos = cur;
        // 指を持ち上げたら座標をリセット
        if (event.getAction() == MotionEvent.ACTION_UP) {
            oldpos = new Point(-1, -1);
        }
        invalidate();
        return true;
    }
}

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

+1

・カラーパレットについて
1-描画する色を変数化します。
2-色を選択するView(ボタンやスライダー)をつくり、対応した色を変数に入れます。
3-変数を下記の箇所に使用します。paint.setColor(Color.BLACK);の箇所で

・保存について
情報が少ないのでログキャットを追記してもらうと回答できると思います。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

checkベストアンサー

-1

保存できない件に関しては、下記をAndroidManifest.xmlに記載していないからではないですか。
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

黒い意外の色を使える様にしたいなら"paint.setColor(Color.BLACK);"に違う色のカラーコードを代入できるメソッドを作りそのメソッドを呼び出すカラーパレッドの様なUIを作ればいいと思います。

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

同じタグがついた質問を見る