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

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

ただいまの
回答率

88.23%

MessageAPIでデータを送信しているはずなのに反応がない

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,206

takasama

score 12

前提・実現したいこと

mobile\SubActivity内のsumKidoの値を1秒毎にwearに送って、その値をwearの画面上に表示するプログラムを作ろうと思っています。

sumKidoをMessageAPIで送れるbyte配列にするために、一旦KidoOkuriというString型の配列に代入してから1秒ごとにsendMessageToWearでbyte配列にしてwearに送る処理をするプログラム(mobile),
送られてきた値を画面上にTextView, setTextで表示するプログラム(wear)

を書いたつもりなんですが実行してもwearの画面に値が表示されないままになってしまいます。

なぜだ!(笑)現在試行錯誤していますが現状手詰まりです…

mobile\SubActivity.java

package com.example.taka.wtf;

import android.app.Activity;
import android.os.Bundle;
import java.io.IOException;
import java.util.Collection;
import java.util.HashSet;
import java.util.Timer;
import java.util.TimerTask;

import android.content.Context;
import android.hardware.Camera;
import android.view.SurfaceHolder;
import android.view.SurfaceView;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Paint.Style;
import android.graphics.PorterDuff.Mode;
import android.graphics.SurfaceTexture;

import com.google.android.gms.common.api.GoogleApiClient;
import com.google.android.gms.wearable.MessageApi;
import com.google.android.gms.wearable.Node;
import com.google.android.gms.wearable.NodeApi;
import com.google.android.gms.wearable.Wearable;


public class SubActivity extends Activity {

    private final static String OKURUATAI = "/itti";
    private GoogleApiClient mGoogleApiClient;
    private float sumKido = 0.0f;
    private static String KidoOkuri = "";


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        CameraView view = new CameraView(this);
        setContentView(view);

        mGoogleApiClient = new GoogleApiClient.Builder(this)
                .addApi(Wearable.API)
                .addConnectionCallbacks(new GoogleApiClient.ConnectionCallbacks() {
                    @Override
                    public void onConnected(Bundle bundle) {
                    }

                    @Override
                    public void onConnectionSuspended(int cause) {
                    }
                }).build();
        mGoogleApiClient.connect();

        Timer timer = new Timer("");
        timer.scheduleAtFixedRate(new TestTimerTask(), 1 * 1000, 1 * 1000);

    }

    class TestTimerTask extends TimerTask {
        public void run() {
            KidoOkuri = String.valueOf(sumKido);
            sendMessageToWear();
            KidoOkuri = "";
        }
    }

    public class CameraView extends SurfaceView implements SurfaceHolder.Callback, Camera.PreviewCallback {
        private Camera mCamera = null;
        private SurfaceTexture mSurfaceTexture = null;
        private static final int Width = 640;
        private static final int Height = 480;
        private int Buffer;
        private float[] Kido;
        private int str;
        private static final int Width2 = 50;
        private static final int Scope = 200;
        private int strstr;
        private int Start;
        private Paint ShindenzuLine = new Paint();
        private SurfaceHolder Holder = null;

        public CameraView(Context context) {
            super(context);
            ShindenzuLine.setColor(Color.rgb(0, 255, 0));
            ShindenzuLine.setStrokeWidth(3);
            ShindenzuLine.setStyle(Style.STROKE);
            Holder = getHolder();
            Holder.addCallback(this);
        }

        public void surfaceCreated(SurfaceHolder holder) {
            Buffer = getWidth();
            Kido = new float[Buffer];
            str = (Buffer - Width2 * 2) / Scope;
            mCamera = Camera.open();
            try {
                mSurfaceTexture = new SurfaceTexture(0);
                mCamera.setPreviewTexture(mSurfaceTexture);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }

        public void surfaceChanged(SurfaceHolder holder, int format, int w, int h) {
            stopPreview();
            Camera.Parameters params = mCamera.getParameters();
            params.setPreviewSize(Width, Height);
            params.setFlashMode(Camera.Parameters.FLASH_MODE_TORCH);
            mCamera.setParameters(params);
            Start = 0;
            strstr = 0;
            startPreview();
        }

        public void surfaceDestroyed(SurfaceHolder holder) {
            stopPreview();
            mCamera.release();
            mCamera = null;
        }

        @Override
        public void onPreviewFrame(byte[] data, Camera camera) {
            Kido[strstr % Buffer] = KidoKeisan(data);
            strstr++;
            Shindenzu();


        }

        private void startPreview() {
            mCamera.setPreviewCallback(this);
            mCamera.startPreview();
        }


        private void stopPreview() {
            mCamera.setPreviewCallback(null);
            mCamera.stopPreview();
        }

        private float KidoKeisan(byte[] data) {
            int frame = 0;
            for (int y = Height / 4; y < Height * 3 / 4; y++) {
                for (int x = Width / 4; x < Width * 3 / 4; x++) {
                    sumKido += (float) (data[y * Width + x] & 0xff);
                    frame++;
                }
            }
            sumKido /= frame;
            return sumKido;
        }

        private void Shindenzu() {
            int idx, idx_1;
            Canvas canvas = Holder.lockCanvas();
            if (canvas != null) {
                canvas.drawColor(0, Mode.CLEAR);
                if (strstr >= Scope) {
                    Start++;
                }
                for (int i = Start, x = 0; i < strstr - 1; i++, x++) {
                    idx = i % Buffer;
                    idx_1 = (i + 1) % Buffer;
                    canvas.drawLine(x * str + Width2, (Kido[idx] - 80) * 20, (x + 1) * str + Width2, (Kido[idx_1] - 80) * 20, ShindenzuLine);
                }
                Holder.unlockCanvasAndPost(canvas);
            }
        }

    }

    private Collection<String> getNodes() {
        HashSet<String> results = new HashSet<String>();
        NodeApi.GetConnectedNodesResult nodes = Wearable.NodeApi.getConnectedNodes(mGoogleApiClient).await();
        for (Node node : nodes.getNodes()) {
            results.add(node.getId());
        }
        return results;
    }

    private void sendMessageToWear() {
        Collection<String> nodes = getNodes();
        for (String node : nodes) {
            MessageApi.SendMessageResult result =
                    Wearable.MessageApi.sendMessage(mGoogleApiClient, node, OKURUATAI,
                    KidoOkuri.getBytes()
                    ).await();
        }
    }

}

wear\MainActivity.java

package com.example.taka.wtf;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.MotionEvent;
import android.widget.TextView;

import com.google.android.gms.common.ConnectionResult;
import com.google.android.gms.common.api.GoogleApiClient;
import com.google.android.gms.wearable.MessageEvent;
import com.google.android.gms.wearable.Wearable;
import com.google.android.gms.wearable.WearableListenerService;


public class MainActivity extends Activity
        implements GoogleApiClient.ConnectionCallbacks, GoogleApiClient.OnConnectionFailedListener{

    int gamenID = R.layout.rect_activity_main;
    private GoogleApiClient mGoogleApiClient;
    int Shin;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.rect_activity_main);

    mGoogleApiClient = new GoogleApiClient
    .Builder(this)
    .addConnectionCallbacks(this)
    .addOnConnectionFailedListener(this)
    .addApi(Wearable.API)
    .build();
    }


    @Override
    protected void onResume() {
        super.onResume();
        mGoogleApiClient.connect();
    }

    @Override
    protected void onPause() {
        super.onPause();
        if (mGoogleApiClient != null && mGoogleApiClient.isConnected()) {
            mGoogleApiClient.disconnect();
        }
    }

    @Override
    public void onConnected(Bundle bundle) {
        Log.d("TAG", "onConnected");
    }

    @Override
    public void onConnectionSuspended(int i) {
        Log.d("TAG", "onConnectionSuspended");
    }

    @Override
    public void onConnectionFailed(ConnectionResult connectionResult) {
        Log.e("TAG", "onConnectionFailed: " + connectionResult);
    }


    public class DataLayerListenerService extends WearableListenerService {
        private final static String OKURUATAI = "/itti";

        @Override
        public void onMessageReceived(MessageEvent messageEvent) {
            if (OKURUATAI.equals(messageEvent.getPath())) {
                final String message = new String(messageEvent.getData());
                Shin = Integer.parseInt(message);
                TextView text = (TextView)findViewById(R.id.textView2);
                text.setText(Shin);
            }
        }
    }
}
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

0

書いたつもりなんですが実行してもwearの画面に値が表示されないままになってしまいます

単体テストをやって確認してから色々な機能を追加したほうがいいですね
そもそもGoogleApiClientが双方コネクトしているか確認できているのでしょうか
メッセージを送っているというログは取れているのでしょうか

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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