Не могу запустить программу

Ответить
Дмитрий
Сообщения: 11
Зарегистрирован: 10 июл 2013, 13:58

Не могу запустить программу

Сообщение Дмитрий » 18 июл 2013, 12:13

Не запускается программа, подскажите почему. Скорее всего напортачил с кнопками.

Код: Выделить всё

package com.example.bluetooth1;

import java.io.IOException;
import java.io.OutputStream;
import java.util.UUID;

import android.app.Activity;
import android.bluetooth.BluetoothAdapter;
import android.bluetooth.BluetoothDevice;
import android.bluetooth.BluetoothSocket;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.widget.Button;
import android.widget.Toast;
  
public class MainActivity extends Activity {
  private static final String TAG = "bluetooth1";
    
  Button btnGo, btnBack, btnRaft, btnLaft;
    
  private static final int REQUEST_ENABLE_BT = 1;
  private BluetoothAdapter btAdapter = null;
  private BluetoothSocket btSocket = null;
  private OutputStream outStream = null;
    
  // SPP UUID сервиса 
  private static final UUID MY_UUID = UUID.fromString("00001101-0000-1000-8000-00805F9B34FB");
  
  // MAC-адрес Bluetooth модуля
  private static String address = "00:15:FF:F2:19:4C";
    
  /** Called when the activity is first created. */
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
  
    setContentView(R.layout.activity_main);
  
    btnGo = (Button) findViewById(R.id.btnGo);
    btnBack = (Button) findViewById(R.id.btnBack);
    btnRaft = (Button) findViewById(R.id.btnRaft);
    btnLaft = (Button) findViewById(R.id.btnLaft);
      
    btAdapter = BluetoothAdapter.getDefaultAdapter();
    checkBTState();
  
    btnGo.setOnTouchListener(new OnTouchListener() 
    { 
    
        public boolean onTouch(View v, MotionEvent event) 
        { 
            if (event.getAction() == MotionEvent.ACTION_DOWN) 
            	sendData("1");
            else if (event.getAction() == MotionEvent.ACTION_UP) 
            	sendData("2");
            return false; 
        } 
    }); 
    
    
    
    btnBack.setOnTouchListener(new OnTouchListener() 
    { 

        public boolean onTouch(View v, MotionEvent event) 
        { 
            if (event.getAction() == MotionEvent.ACTION_DOWN) 
            	sendData("3");
            else if (event.getAction() == MotionEvent.ACTION_UP) 
            	sendData("4");
            return false; 
        } 
    }); 
    btnRaft.setOnTouchListener(new OnTouchListener() 
    { 

        public boolean onTouch(View v, MotionEvent event) 
        { 
            if (event.getAction() == MotionEvent.ACTION_DOWN) 
            	sendData("5");
            else if (event.getAction() == MotionEvent.ACTION_UP) 
            	sendData("6");
            return false; 
        } 
    }); 
    
    btnLaft.setOnTouchListener(new OnTouchListener() 
    { 

        public boolean onTouch(View v, MotionEvent event) 
        { 
            if (event.getAction() == MotionEvent.ACTION_DOWN) 
            	sendData("7");
            else if (event.getAction() == MotionEvent.ACTION_UP) 
            	sendData("8");
            return false; 
        } 
    }); 
  }
    
  @Override
  public void onResume() {
    super.onResume();
  
    Log.d(TAG, "...onResume - попытка соединения...");
    
    // Set up a pointer to the remote node using it's address.
    BluetoothDevice device = btAdapter.getRemoteDevice(address);
    
    // Two things are needed to make a connection:
    //   A MAC address, which we got above.
    //   A Service ID or UUID.  In this case we are using the
    //     UUID for SPP.
    try {
      btSocket = device.createRfcommSocketToServiceRecord(MY_UUID);
    } catch (IOException e) {
      errorExit("Fatal Error", "In onResume() and socket create failed: " + e.getMessage() + ".");
    }
    
    // Discovery is resource intensive.  Make sure it isn't going on
    // when you attempt to connect and pass your message.
    btAdapter.cancelDiscovery();
    
    // Establish the connection.  This will block until it connects.
    Log.d(TAG, "...Соединяемся...");
    try {
      btSocket.connect();
      Log.d(TAG, "...Соединение установлено и готово к передачи данных...");
    } catch (IOException e) {
      try {
        btSocket.close();
      } catch (IOException e2) {
        errorExit("Fatal Error", "In onResume() and unable to close socket during connection failure" + e2.getMessage() + ".");
      }
    }
      
    // Create a data stream so we can talk to server.
    Log.d(TAG, "...Создание Socket...");
  
    try {
      outStream = btSocket.getOutputStream();
    } catch (IOException e) {
      errorExit("Fatal Error", "In onResume() and output stream creation failed:" + e.getMessage() + ".");
    }
  }
  
  @Override
  public void onPause() {
    super.onPause();
  
    Log.d(TAG, "...In onPause()...");
  
    if (outStream != null) {
      try {
        outStream.flush();
      } catch (IOException e) {
        errorExit("Fatal Error", "In onPause() and failed to flush output stream: " + e.getMessage() + ".");
      }
    }
  
    try     {
      btSocket.close();
    } catch (IOException e2) {
      errorExit("Fatal Error", "In onPause() and failed to close socket." + e2.getMessage() + ".");
    }
  }
    
  private void checkBTState() {
    // Check for Bluetooth support and then check to make sure it is turned on
    // Emulator doesn't support Bluetooth and will return null
    if(btAdapter==null) { 
      errorExit("Fatal Error", "Bluetooth не поддерживается");
    } else {
      if (btAdapter.isEnabled()) {
        Log.d(TAG, "...Bluetooth включен...");
      } else {
        //Prompt user to turn on Bluetooth
        Intent enableBtIntent = new Intent(btAdapter.ACTION_REQUEST_ENABLE);
        startActivityForResult(enableBtIntent, REQUEST_ENABLE_BT);
      }
    }
  }
  
  private void errorExit(String title, String message){
    Toast.makeText(getBaseContext(), title + " - " + message, Toast.LENGTH_LONG).show();
    finish();
  }
  
  private void sendData(String message) {
    byte[] msgBuffer = message.getBytes();
  
    Log.d(TAG, "...Посылаем данные: " + message + "...");
  
    try {
      outStream.write(msgBuffer);
    } catch (IOException e) {
      String msg = "In onResume() and an exception occurred during write: " + e.getMessage();
      if (address.equals("00:00:00:00:00:00")) 
        msg = msg + ".\n\nВ переменной address у вас прописан 00:00:00:00:00:00, вам необходимо прописать реальный MAC-адрес Bluetooth модуля";
        msg = msg +  ".\n\nПроверьте поддержку SPP UUID: " + MY_UUID.toString() + " на Bluetooth модуле, к которому вы подключаетесь.\n\n";
        
        errorExit("Fatal Error", msg);       
    }
  }
}

Аватара пользователя
Foenix
Сообщения: 4201
Зарегистрирован: 20 окт 2012, 12:01

Re: Не могу запустить программу

Сообщение Foenix » 18 июл 2013, 12:25

скопировал где-то код, не разобрался, запускаешь, не смотрел даже в логи, что делает программа не ясно..
R.id.team

NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198

Дмитрий
Сообщения: 11
Зарегистрирован: 10 июл 2013, 13:58

Re: Не могу запустить программу

Сообщение Дмитрий » 18 июл 2013, 15:11

Foenix писал(а):скопировал где-то код, не разобрался, запускаешь, не смотрел даже в логи, что делает программа не ясно..
я просил помочь, а не прокомментировать что я скопировал где-то код

Аватара пользователя
Foenix
Сообщения: 4201
Зарегистрирован: 20 окт 2012, 12:01

Re: Не могу запустить программу

Сообщение Foenix » 18 июл 2013, 15:39

а я тебе намекаю, что исходных данных для помощи не хватает. У всех работа, времени тоже не много - нужно уточнять конкретнее что нужно, какова была цель, выложить логи и т.д.
R.id.team

NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198

Дмитрий
Сообщения: 11
Зарегистрирован: 10 июл 2013, 13:58

Re: Не могу запустить программу

Сообщение Дмитрий » 18 июл 2013, 15:56

Foenix писал(а):а я тебе намекаю, что исходных данных для помощи не хватает. У всех работа, времени тоже не много - нужно уточнять конкретнее что нужно, какова была цель, выложить логи и т.д.
Цель послать сигнал на блютус с телефона на ардуино. Но с кнопками запутался совсем :( у кого если есть время помогите пожалуйста.

Аватара пользователя
Foenix
Сообщения: 4201
Зарегистрирован: 20 окт 2012, 12:01

Re: Не могу запустить программу

Сообщение Foenix » 18 июл 2013, 16:01

а лог ошибок?
R.id.team

NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198

Дмитрий
Сообщения: 11
Зарегистрирован: 10 июл 2013, 13:58

Re: Не могу запустить программу

Сообщение Дмитрий » 18 июл 2013, 16:05

что за лог ошибок?( я олень совсем еще в программировании)

Аватара пользователя
Foenix
Сообщения: 4201
Зарегистрирован: 20 окт 2012, 12:01

Re: Не могу запустить программу

Сообщение Foenix » 18 июл 2013, 16:15

Внизу есть окошко LogCat. Там красным или оранжевым выдаются ошибки, а просто логи - черным.
Читаешь что за ошибка, щелкаешь*2 по словам at... указывающим на адрес в твоей программе, где есть ссылка на метод и строку ошибочную - она тебе в эту строку переносишь, смотришь что не так.
Начинай лучше разбираться с 1 го урока, дойди хотя бы до 10-15, потом будешь лучше соображать что к чему. Так сложно и ошибки исправлять, а если кто-то тебе исправит - все равно ничего дальше не поймешь..
R.id.team

NullPointerException - что делать???
viewtopic.php?f=33&t=3899&p=28952#p28952
Где моя ошибка?
viewtopic.php?f=60&t=3198

Дмитрий
Сообщения: 11
Зарегистрирован: 10 июл 2013, 13:58

Re: Не могу запустить программу

Сообщение Дмитрий » 18 июл 2013, 16:18

Извиняюсь за флуд парни, уже сам разобрался :)

Ответить