0

私は助けが必要です。 二次活動 パッケージ archtectsproductions.scriptpyandroidwearwatchface;

import android.app.Activity;
import android.content.res.Resources;
import android.os.Bundle;
import android.support.wearable.view.WatchViewStub;
import android.view.View;
import android.widget.Button;
import android.widget.RadioButton;
import android.widget.RadioGroup;
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.PutDataMapRequest;
import com.google.android.gms.wearable.PutDataRequest;
import com.google.android.gms.wearable.Wearable;

import static android.graphics.Color.BLUE;
import static android.graphics.Color.GREEN;
import static android.graphics.Color.RED;


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

private GoogleApiClient mGoogleApiClient;
private int mTextColor = 0xffffffff;

private TextView mTextView;

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

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

    Button buttonOK = (Button)findViewById(R.id.buttonOK);
    buttonOK.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            RadioGroup radioTextColor =
                    (RadioGroup)findViewById(R.id.rGroup);
            int selectedId = radioTextColor.getCheckedRadioButtonId();
            switch (selectedId) {
                default:
                case R.id.rDarkpastel:
                    mTextColor = 0xffffffff;
                    break;
                case R.id.Notepad:
                        mTextColor = GREEN;
                    break;
                case R.id.rHarvenjark:
                        mTextColor = BLUE;
                    break;
                case R.id.rVibrant:
                        mTextColor = RED;
                    break;

            }
            sendParamsAndFinish();
        }
    });
}

// sends data through Google API
private void sendParamsAndFinish() {
    PutDataMapRequest putDataMapReq =
            PutDataMapRequest.create("/watch_face_config_cliu");
    putDataMapReq.getDataMap().putInt("text_color", mTextColor);
    PutDataRequest putDataReq = putDataMapReq.asPutDataRequest();
    Wearable.DataApi.putDataItem(mGoogleApiClient, putDataReq);

    finish();
}

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

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

@Override
public void onConnected(Bundle bundle) {
}

@Override
public void onConnectionSuspended(int i) {
}

@Override
public void onConnectionFailed(ConnectionResult connectionResult) {
    }

}

メイン public class WatchFaceCLiuService extends CanvasWatchFaceService { private static final long UPDATE_INTERVAL = TimeUnit.SECONDS.toMillis(1);

@Override
public Engine onCreateEngine() {
    return new Engine();
}

private class Engine extends CanvasWatchFaceService.Engine implements
        GoogleApiClient.ConnectionCallbacks,
            GoogleApiClient.OnConnectionFailedListener {
    ...
    private GoogleApiClient mGoogleApiClient;                
    private int mTextColor = 0xffffffff;
    private float offsetx = (float)(-50 + 100 * Math.random());
    private float offsety = (float)(-50 + 100 * Math.random());

    @Override
    public void onCreate(SurfaceHolder holder) {
        super.onCreate(holder);
        ...
        mGoogleApiClient = new GoogleApiClient.Builder(WatchFaceCLiuService.this)
                .addApi(Wearable.API)
                .addConnectionCallbacks(this)
                .addOnConnectionFailedListener(this)
                .build();
    }

    ...

    @Override
    public void onDraw(Canvas canvas, Rect bounds) {            
        ...
        canvas.drawText(ts1, tx1, ty1, mDigitalPaint);
        ...
    }

    private void releaseGoogleApiClient() {
        if (mGoogleApiClient != null && mGoogleApiClient.isConnected()) {
            Wearable.DataApi.removeListener(mGoogleApiClient,
                onDataChangedListener);
            mGoogleApiClient.disconnect();
        }
    }

    @Override
    public void onConnected(Bundle bundle) {
        Wearable.DataApi.addListener(mGoogleApiClient,
            onDataChangedListener);
        Wearable.DataApi.getDataItems(mGoogleApiClient).
            setResultCallback(onConnectedResultCallback);
    }

    private void updateParamsForDataItem(DataItem item) {
        if ((item.getUri().getPath()).equals("/watch_face_config_cliu")) {
            DataMap dataMap = DataMapItem.fromDataItem(item).getDataMap();
            if (dataMap.containsKey("text_color")) {
                int tc = dataMap.getInt("text_color");
                mDigitalPaint.setColor(tc);
                invalidate();
            }
        }
    }

    private final DataApi.DataListener onDataChangedListener =
            new DataApi.DataListener() {
        @Override
        public void onDataChanged(DataEventBuffer dataEvents) {
            for (DataEvent event : dataEvents) {
                if (event.getType() == DataEvent.TYPE_CHANGED) {
                    DataItem item = event.getDataItem();
                    updateParamsForDataItem(item);
                }
            }

            dataEvents.release();
            if (isVisible() && !isInAmbientMode()) {
                invalidate();
            }
        }
    };

    private final ResultCallback<DataItemBuffer>
            onConnectedResultCallback =
            new ResultCallback<DataItemBuffer>() {
        @Override
        public void onResult(DataItemBuffer dataItems) {
            for (DataItem item : dataItems) {
                updateParamsForDataItem(item);
            }

            dataItems.release();
            if (isVisible() && !isInAmbientMode()) {
                invalidate();
            }
        }
    };

    @Override
    public void onConnectionSuspended(int i) {
    }

    @Override
    public void onConnectionFailed(ConnectionResult
        connectionResult) {
    }

    @Override
    public void onDestroy() {
        mUpdateTimeHandler.removeMessages(MESSAGE_ID_UPDATE_TIME);
        releaseGoogleApiClient();
        super.onDestroy();
    }
}
}

私は本当に助けが必要です、私はレンガの壁に頭をぶつけています。これはうまくいきません。int をまったく送信しません。私はガイドに従いました。私は最善を尽くしましたが、送信されません。誰かがより良い方法を知っていますか? グローバルにすればいいの?それはうまくいきますが、キャンバスウォッチフェイスサービスで使用できるコードに制限があるように見えるため、idがどのように機能するかわかりません。

私が望むのは、あるアクティビティから別のアクティビティに int を送信することだけです。コンパニオンではなくウォッチフェイス サービスを使用する。学びたい。したがって、答えた場合は、コードを貼り付けるだけの方が簡単で、コードをたどって解読できる場合を除き、コードをそのまま貼り付けないでください。

助けてくれてありがとう。

<-- old ユーザーのラジオボタンの選択を保存し、それを別のアクティビティに置いて、たとえばテキストの色を変更する単純なアプリをJavaで作成する方法を理解していますが、アンドロイドウェアでそうするのに苦労しています。

その理由は、次のことを実装できないからです。

@overide
public void onCreate(Bundle savedInstanceState){
     super.onCreate(savedInstanceState);
      Radiogroup = (RadioGroup)findViewById(R.id.myyrad);
      Radiogroup.setOnCheckedChangedListener(new OnCheckedChangedListener()) { ....

以下は壁紙サービスで実装できませんか?

代替手段はありますか?それとも、非常に紛らわしい googleapiclient ルートに行かなければなりませんか? どんな助けでも大歓迎ですありがとう。

4

1 に答える 1

0

これは解決しました。チュートリアルや私のコードに問題はありません。Studio は別の Android Play サービスを探していました。グレードで変更しました

于 2016-11-24T07:29:09.230 に答える