`
abc20899
  • 浏览: 934944 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Android手机蓝牙控制智能小车机器人

阅读更多
下面开始介绍Android手机端控制程序的编写:

首先打开Eclipse,当然之前的Java开发环境和安卓开发工具自己得先配置好,这里就不多说了,网上教程一大摞。

然后新建一个Android项目,修改布局文件main.xml,代码如下:

<?xml version="1.0" encoding="utf-8"?>
<AbsoluteLayout
android:id="@+id/widget0"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
xmlns:android="http://schemas.android.com/apk/res/android"
>
<Button
android:id="@+id/btnF"
android:layout_width="100px"
android:layout_height="60px"
android:text="前进"
android:layout_x="130px"
android:layout_y="62px"
>
</Button>
<Button
android:id="@+id/btnL"
android:layout_width="100px"
android:layout_height="60px"
android:text="左转"
android:layout_x="20px"
android:layout_y="152px"
>
</Button>
<Button
android:id="@+id/btnR"
android:layout_width="100px"
android:layout_height="60px"
android:text="右转"
android:layout_x="240px"
android:layout_y="152px"
>
</Button>
<Button
android:id="@+id/btnB"
android:layout_width="100px"
android:layout_height="60px"
android:text="后退"
android:layout_x="130px"
android:layout_y="242px"
>
</Button>
<Button
android:id="@+id/btnS"
android:layout_width="100px"
android:layout_height="60px"
android:text="停止"
android:layout_x="130px"
android:layout_y="152px"
>
</Button>
</AbsoluteLayout>

这个布局文件的效果就是如视频中所示的手机操作界面。

然后是权限声明,这一步不能少,否则将无法使用安卓手机的蓝牙功能。

权限声明如下:

打开AndroidManifest.xml文件,修改代码如下:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.ThinBTClient.www"
android:versionCode="1"
android:versionName="1.0">

<uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
<uses-permission android:name="android.permission.BLUETOOTH" />
<application android:icon="@drawable/icon" android:label="@string/app_name">
<activity android:name=".ThinBTClient"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>

</application>
</manifest>

其中红色、加粗部分就是要添加的权限声明。

然后编写Activity中的执行代码,这些代码的作用就是发送指令,控制小车的运动。

代码如下:

package com.ThinBTClient.www;

import android.app.Activity;
import android.os.Bundle;
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.DialogInterface;
import android.content.DialogInterface.OnClickListener;

import android.os.Bundle;
import android.provider.ContactsContract.CommonDataKinds.Event;

import android.util.Log;
import android.view.MotionEvent;
import android.view.View;

import android.widget.Button;
import android.widget.Toast;
public class ThinBTClient extends Activity {
private static final String TAG = "THINBTCLIENT";

private static final boolean D = true;

private BluetoothAdapter mBluetoothAdapter = null;

private BluetoothSocket btSocket = null;

private OutputStream outStream = null;
Button mButtonF;

Button mButtonB;
Button mButtonL;
Button mButtonR;
Button mButtonS;


private static final UUID MY_UUID = UUID.fromString("00001101-0000-1000-8000-00805F9B34FB");


private static String address = "00:11:03:21:00:43"; // <==要连接的蓝牙设备MAC地址


/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);
setContentView(R.layout.main);

//前进
mButtonF=(Button)findViewById(R.id.btnF);
mButtonF.setOnTouchListener(new Button.OnTouchListener(){

@Override
public boolean onTouch(View v, MotionEvent event) {
// TODO Auto-generated method stub
String message;
byte[] msgBuffer;
int action = event.getAction();
switch(action)
{
case MotionEvent.ACTION_DOWN:
try {
outStream = btSocket.getOutputStream();

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Output stream creation failed.", e);
}


message = "1";

msgBuffer = message.getBytes();

try {
outStream.write(msgBuffer);

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Exception during write.", e);
}
break;

case MotionEvent.ACTION_UP:
try {
outStream = btSocket.getOutputStream();

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Output stream creation failed.", e);
}


message = "0";

msgBuffer = message.getBytes();

try {
outStream.write(msgBuffer);

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Exception during write.", e);
}
break;
}
return false;
}


});
//后退
mButtonB=(Button)findViewById(R.id.btnB);
mButtonB.setOnTouchListener(new Button.OnTouchListener(){


@Override
public boolean onTouch(View v, MotionEvent event) {
// TODO Auto-generated method stub
String message;
byte[] msgBuffer;
int action = event.getAction();
switch(action)
{
case MotionEvent.ACTION_DOWN:
try {
outStream = btSocket.getOutputStream();

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Output stream creation failed.", e);
}


message = "3";

msgBuffer = message.getBytes();

try {
outStream.write(msgBuffer);

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Exception during write.", e);
}
break;

case MotionEvent.ACTION_UP:
try {
outStream = btSocket.getOutputStream();

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Output stream creation failed.", e);
}


message = "0";

msgBuffer = message.getBytes();

try {
outStream.write(msgBuffer);

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Exception during write.", e);
}
break;
}

return false;
}


});
//左转
mButtonL=(Button)findViewById(R.id.btnL);
mButtonL.setOnTouchListener(new Button.OnTouchListener(){

@Override
public boolean onTouch(View v, MotionEvent event) {
// TODO Auto-generated method stub
String message;
byte[] msgBuffer;
int action = event.getAction();
switch(action)
{
case MotionEvent.ACTION_DOWN:
try {
outStream = btSocket.getOutputStream();

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Output stream creation failed.", e);
}


message = "2";

msgBuffer = message.getBytes();

try {
outStream.write(msgBuffer);

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Exception during write.", e);
}
break;

case MotionEvent.ACTION_UP:
try {
outStream = btSocket.getOutputStream();

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Output stream creation failed.", e);
}


message = "0";

msgBuffer = message.getBytes();

try {
outStream.write(msgBuffer);

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Exception during write.", e);
}
break;
}

return false;

}
});
//右转
mButtonR=(Button)findViewById(R.id.btnR);
mButtonR.setOnTouchListener(new Button.OnTouchListener(){

@Override
public boolean onTouch(View v, MotionEvent event) {
// TODO Auto-generated method stub
String message;
byte[] msgBuffer;
int action = event.getAction();
switch(action)
{
case MotionEvent.ACTION_DOWN:
try {
outStream = btSocket.getOutputStream();

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Output stream creation failed.", e);
}


message = "4";

msgBuffer = message.getBytes();

try {
outStream.write(msgBuffer);

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Exception during write.", e);
}
break;

case MotionEvent.ACTION_UP:
try {
outStream = btSocket.getOutputStream();

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Output stream creation failed.", e);
}


message = "0";

msgBuffer = message.getBytes();

try {
outStream.write(msgBuffer);

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Exception during write.", e);
}
break;
}

return false;

}


});

//停止
mButtonS=(Button)findViewById(R.id.btnS);
mButtonS.setOnTouchListener(new Button.OnTouchListener(){

@Override
public boolean onTouch(View v, MotionEvent event) {
// TODO Auto-generated method stub
if(event.getAction()==MotionEvent.ACTION_DOWN)
try {
outStream = btSocket.getOutputStream();

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Output stream creation failed.", e);
}


String message = "0";

byte[] msgBuffer = message.getBytes();

try {
outStream.write(msgBuffer);

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Exception during write.", e);
}
return false;
}


});



if (D)
Log.e(TAG, "+++ ON CREATE +++");
mBluetoothAdapter = BluetoothAdapter.getDefaultAdapter();

if (mBluetoothAdapter == null) {
Toast.makeText(this, "Bluetooth is not available.", Toast.LENGTH_LONG).show();
finish();
return;
}


if (!mBluetoothAdapter.isEnabled()) {
Toast.makeText(this, "Please enable your Bluetooth and re-run this program.", Toast.LENGTH_LONG).show();
finish();
return;

}


if (D)
Log.e(TAG, "+++ DONE IN ON CREATE, GOT LOCAL BT ADAPTER +++");

}


@Override

public void onStart() {

super.onStart();

if (D) Log.e(TAG, "++ ON START ++");
}


@Override

public void onResume() {

super.onResume();
if (D) {
Log.e(TAG, "+ ON RESUME +");
Log.e(TAG, "+ ABOUT TO ATTEMPT CLIENT CONNECT +");

}

BluetoothDevice device = mBluetoothAdapter.getRemoteDevice(address);

try {

btSocket = device.createRfcommSocketToServiceRecord(MY_UUID);

} catch (IOException e) {

Log.e(TAG, "ON RESUME: Socket creation failed.", e);

}
mBluetoothAdapter.cancelDiscovery();
try {

btSocket.connect();

Log.e(TAG, "ON RESUME: BT connection established, data transfer link open.");

} catch (IOException e) {

try {
btSocket.close();

} catch (IOException e2) {

Log .e(TAG,"ON RESUME: Unable to close socket during connection failure", e2);
}

}


// Create a data stream so we can talk to server.

if (D)
Log.e(TAG, "+ ABOUT TO SAY SOMETHING TO SERVER +");
/* try {
outStream = btSocket.getOutputStream();

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Output stream creation failed.", e);
}


String message = "1";

byte[] msgBuffer = message.getBytes();

try {
outStream.write(msgBuffer);

} catch (IOException e) {
Log.e(TAG, "ON RESUME: Exception during write.", e);
}
*/

}


@Override

public void onPause() {

super.onPause();


if (D)
Log.e(TAG, "- ON PAUSE -");
if (outStream != null) {
try {
outStream.flush();
} catch (IOException e) {
Log.e(TAG, "ON PAUSE: Couldn't flush output stream.", e);
}

}


try {
btSocket.close();
} catch (IOException e2) {
Log.e(TAG, "ON PAUSE: Unable to close socket.", e2);
}

}


@Override

public void onStop() {

super.onStop();

if (D)Log.e(TAG, "-- ON STOP --");

}


@Override

public void onDestroy() {

super.onDestroy();

if (D) Log.e(TAG, "--- ON DESTROY ---");

}

}

可以看到,在这个程序中我直接把小车蓝牙模块的MAC地址给写进去了,其实更合理一点应该让程序运行后搜索周围蓝牙设备,然后选择需要连接的设备,获取它的MAC地址再连接,但是我为了图省事,就直接把我的小车的蓝牙MAC给定死了(反正也没那么多小车让我遥控~~~),这样一打开程序,手机将自动连接智能小车。

好了,手机端的开发到此介绍完毕~希望能为需要者提供一点帮助。

下一步是打算增加红外避障功能、超声波测距功能,机械手臂,如果有机会,以后再安装上火控系统发射钻天猴~,不过估计时间不太允许了······



再次鄙视光显摆却不肯分享技术的装X党!

分享到:
评论

相关推荐

    成功实现手机蓝牙控制智能小车机器人!视频+程序源代码(Android).doc

    Android 手机蓝牙控制智能小车机器人的实现对大家来说是一个很有挑战性的任务,但是通过这篇文章,我们可以看到作者经过努力和研究,最终成功实现了这个项目。下面我们将对这个项目的关键技术点进行详细的分析和总结...

    Android手机蓝牙智能小车机器人控制端V1.0

    Android手机蓝牙智能小车机器人控制端V1.0 通过Android手机发送16进制数据协议包,控制“蓝莓”蓝牙智能小车机器人驱动板运行。 WIFI机器人网·机器人创意工作室:www.wifi-robots.com版权所有 by liuviking

    手机蓝牙控制智能小车机器人

    上次成功实现了通过笔记本电脑蓝牙来控制智能小车机器人的运动但是通过电脑控制毕竟 不方便于是乎~本人打算将控制程序移植到手机上。

    成功实现手机蓝牙控制智能小车机器人视频+程序源代码Android.doc

    成功实现手机蓝牙控制智能小车机器人视频+程序源代码Android.doc

    Android手机重力感应遥控智能小车机器人源码

    在本项目中,"Android手机重力感应遥控智能小车机器人源码" 是一个利用Android设备的重力感应传感器来远程控制智能小车的软件应用。这个应用的核心是通过读取手机内置的加速度计(Accelerometer)数据,将用户的手机...

    智能小车蓝牙控制android

    智能小车蓝牙控制Android技术是将现代化的移动设备与物联网技术相结合的一种应用,它使得用户可以通过智能手机对小型机器人车辆进行远程操控。这个项目的核心在于利用蓝牙通信协议建立Android设备与智能小车之间的...

    基于安卓手机蓝牙遥控智能小车.pdf

    在这样的背景下,基于安卓手机蓝牙遥控智能小车的设计应运而生,旨在突破传统遥控小车只能用特定遥控器控制的局限性,为用户提供更加灵活、便捷的控制方式。 该智能小车的设计主要由三个核心模块组成:蓝牙模块、...

    基于安卓手机蓝牙遥控智能小车.docx

    本文介绍了一种基于安卓手机蓝牙遥控智能小车的设计方案,通过使用手机蓝牙模块和单片机控制,可以实现遥控小车的控制。该设计方案包括手机蓝牙模块、单片机控制模块、电机驱动模块等硬件模块,通过 Appinventor ...

    蓝牙远程控制小车

    【蓝牙远程控制小车】是一种基于蓝牙通信技术的智能玩具或教育项目,它允许用户通过智能手机或其他设备远程操控小车的行驶方向、速度以及其他可能的功能。实现这样的系统涉及多个技术领域,包括硬件接口设计、软件...

    基于Qt的串口上位机控制蓝牙小车程序

    **基于Qt的串口上位机控制蓝牙小车程序** 在物联网和自动化领域,通过上位机对下位机进行远程或本地控制是一项常见的任务。本项目“基于Qt的串口上位机控制蓝牙小车程序”就是这样一个例子,它利用Qt框架构建了一个...

    手机控制蓝牙小车

    蓝牙小车是利用蓝牙通信技术,将智能手机与小型移动机器人连接,实现远程操控的一种装置。让我们一起探索这个领域的核心技术和实践方法。 首先,我们需要了解蓝牙通信的基本原理。蓝牙是一种短距离无线通信技术,...

    基于Android系统的智能小车的设计与实现.docx

    其中,利用Android智能手机控制智能小车不仅能够满足教育和娱乐的需求,还能应用于危险环境下的探索与检测工作,具有重要的实用价值和广阔的应用前景。本文介绍了基于Android系统的智能小车的设计与实现方法。 ####...

    安卓手机控制小车

    【安卓手机控制小车】是一项将移动设备与物联网技术结合的创新应用,它利用安卓手机的蓝牙功能,通过HC04蓝牙模块与单片机进行数据通信,从而实现对小车运动状态的远程控制。这一技术的应用使得用户可以通过手机应用...

    慧净蓝牙小车HJ-E教程

    慧净蓝牙小车HJ-E是一款集成了蓝牙通信技术的智能小车,适用于教育、娱乐以及初级机器人爱好者进行学习和探索。本教程旨在帮助用户掌握如何操作和编程这款小车,通过蓝牙连接与Android设备进行互动。 一、蓝牙小车...

    基于Android的智能小车设计.pdf

    1. **Android客户端应用开发**:此设计中的Android应用是控制智能小车的关键部分,用户可以通过手机实时发送指令,控制小车移动和机械臂的动作。开发者使用Eclipse等Android Studio开发环境,编写Java或Kotlin代码,...

    基于Android平台的无线遥控智能小车.pdf

    该智能小车系统采用Android设备作为上位机控制器,利用蓝牙和WiFi技术进行无线通信,实现了远程控制、路径追踪、障碍物避让、寻光以及视频监控等多种功能。 在硬件设计上,核心控制器是STC12C5A60S2单片机,这是一...

    无需编程_DIY自己智能小车的Android蓝牙遥控软件

    ### 无需编程_DIY自己智能小车的Android蓝牙遥控软件 #### 一、概述 本文旨在介绍如何利用AppInventor这款云端Android程序开发工具,为自己的智能小车设计一个无需编程基础的蓝牙遥控应用程序。对于许多热爱DIY...

    蓝牙控制小车

    【蓝牙控制小车】是一种利用蓝牙通信技术实现无线遥控的小型车辆模型,它结合了现代电子技术、嵌入式系统和无线通信技术,为DIY爱好者和机器人爱好者提供了丰富的实践平台。这种小车通常配备有微控制器,通过接收...

    重力感应无线小车源码

    用户可以通过智能手机或其他支持蓝牙的设备发送指令到小车,控制其运动。 3. STM32微控制器:STM32系列微控制器拥有丰富的外设接口,如I²C、SPI、UART等,可以方便地连接各种传感器和无线模块。其内置的ARM Cortex...

Global site tag (gtag.js) - Google Analytics