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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Q&A

2回答

315閲覧

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

H30_inenaga

総合スコア18

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

0グッド

0クリップ

投稿2019/01/12 07:41

編集2019/01/12 15:48

実現したい機能

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

1<?xml version="1.0" encoding="utf-8"?> 2<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 3 xmlns:tools="http://schemas.android.com/tools" 4 android:layout_width="match_parent" 5 android:layout_height="match_parent"> 6 7 <TextView 8 android:textSize="40sp" 9 android:id="@+id/text" 10 android:layout_width="wrap_content" 11 android:layout_height="wrap_content" 12 android:text="タッチしてね!" 13 android:layout_alignParentTop="true" 14 android:layout_centerHorizontal="true"/> 15 "/> 16 17 <Button 18 android:text="start" 19 android:id="@+id/start_button" 20 android:layout_width="match_parent" 21 android:layout_height="wrap_content" 22 android:layout_marginLeft="10dp" 23 android:layout_marginRight="10dp" 24 android:layout_centerVertical="true" 25 android:layout_alignParentEnd="true"/> 26 27 <Button 28 android:text="stop" 29 android:id="@+id/stop_button" 30 android:layout_width="match_parent" 31 android:layout_height="wrap_content" 32 android:layout_marginLeft="10dp" 33 android:layout_marginRight="10dp" 34 android:layout_marginBottom="133dp" 35 android:layout_alignParentBottom="true" 36 android:layout_alignStart="@+id/start_button"/> 37 38 <TextView 39 android:id="@+id/timer" 40 android:layout_width="wrap_content" 41 android:layout_height="wrap_content" 42 android:text="TextView" 43 /> 44</RelativeLayout>

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

API 26(android Oreo)以前は

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

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

投稿2019/01/12 18:35

Kota_Kappa

総合スコア116

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

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

投稿2019/01/12 08:16

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

H30_inenaga

2019/01/12 15:49

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

退会済みユーザー

2019/01/13 06:15

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問