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

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

ただいまの
回答率

89.97%

タップするとストップウォッチが作動するプログラム

受付中

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 378

H30_inenaga

score 16

実現したい機能

1.スマートフォンAとスマートフォンBをソケット通信で通信する機能

2.スマートフォンAがボタンを押して、スマートフォンBにメッセージを送信する。(このとき、ボタン押下と同時にスマートフォンAのストップウォッチが動作開始)

3.スマートフォンBにメッセージが届いたら、画面のどこでも良いからタップする(ボタンは作りません!)とスマートフォンBのストップウォッチが作動する。(このとき、スマートフォンAにイベントを送信して、スマートフォンAのストップウォッチを止める)

といった、要はストップウォッチの遠隔操作機能を作りたいです。

ちなみに、1、2の機能は正しく動作できることを確認しました。
3に関して、画面のどこかをタップすると、スマートフォンBのストップウォッチが作動する機能と、スマートフォンAにイベントを送信して、スマートフォンAのストップウォッチを止める機能ができていません。

今は、画面のどこかをタップすると、スマートフォンBのストップウォッチが作動する機能のみを作成中です。(ストップウォッチの初期タイプを作るためにあえてボタンを作っています。ボタンではなく、タップしたらストップウォッチが動作するようにするにはどうプログラムをすればよいでしょうか?)

エラーメッセージ

Error:(32, 33) エラー: 不適合な型: ViewをTextViewに変換できません:
Error:(35, 35) エラー: 不適合な型: ViewをButtonに変換できません:
Error:(38, 41) エラー: 不適合な型: ViewをButtonに変換できません:

どうも、findViewByIdがダメなようなのですが、、

ソースコード 

以下にソースコードを掲載しますが、参考サイトなど教えていただけると幸いです。

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.MotionEvent;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import java.util.Locale;
import java.text.SimpleDateFormat;
import android.os.Handler;
public class MainActivity extends AppCompatActivity implements
        Runnable, View.OnClickListener {

    private long startTime;

    private TextView timerText;
    private Button startButton;

    private final Handler handler = new Handler();
    private volatile boolean stopRun = false;

    private SimpleDateFormat dataFormat =
            new SimpleDateFormat("mm:ss.SS", Locale.JAPAN);

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


        timerText = findViewById(R.id.timer);
        timerText.setText(dataFormat.format(0));

        startButton = findViewById(R.id.start_button);
        startButton.setOnClickListener(this);

        Button stopButton = findViewById(R.id.stop_button);
        stopButton.setOnClickListener(this);
        // タッチイベント(画面タッチを感知する)

    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {

        // 文字の変更
        ((TextView) findViewById(R.id.text)).setText("タッチしたよ!!");

        return super.onTouchEvent(event);
    }

    @Override
    public void onClick(View v) {
        Thread thread;
        if (v == startButton) {
            stopRun = false;
            thread = new Thread(this);
            thread.start();

            startTime = System.currentTimeMillis();

        } else {
            stopRun = true;
            timerText.setText(dataFormat.format(0));
        }
    }

    @Override
    public void run() {
        // 10 msec order
        int period = 10;

        while (!stopRun) {
            // sleep: period msec
            try {
                Thread.sleep(period);
            } catch (InterruptedException e) {
                e.printStackTrace();
                stopRun = true;
            }

            handler.post(new Runnable() {
                @Override
                public void run() {
                    long endTime = System.currentTimeMillis();
                    // カウント時間 = 経過時間 - 開始時間
                    long diffTime = (endTime - startTime);

                    timerText.setText(dataFormat.format(diffTime));

                }
            });
        }
    }
}
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
                xmlns:tools="http://schemas.android.com/tools"
                android:layout_width="match_parent"
                android:layout_height="match_parent">

    <TextView
        android:textSize="40sp"
        android:id="@+id/text"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="タッチしてね!"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"/>
    "/>

    <Button
        android:text="start"
        android:id="@+id/start_button"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dp"
        android:layout_marginRight="10dp"
        android:layout_centerVertical="true"
        android:layout_alignParentEnd="true"/>

    <Button
        android:text="stop"
        android:id="@+id/stop_button"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dp"
        android:layout_marginRight="10dp"
        android:layout_marginBottom="133dp"
        android:layout_alignParentBottom="true"
        android:layout_alignStart="@+id/start_button"/>

    <TextView
        android:id="@+id/timer"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="TextView"
        />
</RelativeLayout>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

0

・レイアウトと違う型を指定している
・compileSdkVersionが古い
あたりですかね

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/01/13 00:49

    レイアウトと同じ型になるようプログラミングしたつもりですが、どこら辺が違う型なのでしょうか?

    キャンセル

  • 2019/01/13 15:15

    ああ、同じなんですね。
    ではcompileSdkVersionかTargetSdkVersionあたりがAPI26より前ではないですか?

    キャンセル

0

API 26(android Oreo)以前は

Button button = (Button)findViewById(R.id.button1)

のように書かなければならなかったので、その辺とか?
どうも、onTouchEventではキャストしていたり、onCreateでは省いてあったりで
統一性がないのでそう感じました。 
API26以降であれば、わざわざキャストしてもエラーにはならないので原因は別にあることになります

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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