1. package myself.mqtt.wenzheng.studio.mqtt;
  2.  
  3. import android.app.Notification;
  4. import android.app.NotificationManager;
  5. import android.content.Context;
  6. import android.content.Intent;
  7. import android.os.Bundle;
  8. import android.os.Handler;
  9. import android.os.IBinder;
  10. import android.os.Message;
  11. import android.support.design.widget.FloatingActionButton;
  12. import android.support.design.widget.Snackbar;
  13. import android.support.v4.app.NotificationCompat;
  14. import android.util.Log;
  15. import android.view.KeyEvent;
  16. import android.view.View;
  17. import android.support.design.widget.NavigationView;
  18. import android.support.v4.view.GravityCompat;
  19. import android.support.v4.widget.DrawerLayout;
  20. import android.support.v7.app.ActionBarDrawerToggle;
  21. import android.support.v7.app.AppCompatActivity;
  22. import android.support.v7.widget.Toolbar;
  23. import android.view.Menu;
  24. import android.view.MenuItem;
  25. import android.widget.RemoteViews;
  26. import android.widget.Toast;
  27.  
  28. import org.eclipse.paho.client.mqttv3.IMqttDeliveryToken;
  29. import org.eclipse.paho.client.mqttv3.MqttCallback;
  30. import org.eclipse.paho.client.mqttv3.MqttClient;
  31. import org.eclipse.paho.client.mqttv3.MqttConnectOptions;
  32. import org.eclipse.paho.client.mqttv3.MqttException;
  33. import org.eclipse.paho.client.mqttv3.MqttMessage;
  34. import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;
  35.  
  36. import java.util.concurrent.Executors;
  37. import java.util.concurrent.ScheduledExecutorService;
  38. import java.util.concurrent.TimeUnit;
  39.  
  40. public class MainActivity extends AppCompatActivity
  41. implements NavigationView.OnNavigationItemSelectedListener {
  42. private String host = "tcp://60.205.203.64:1883";
  43. private String userName = "admin";
  44. private String passWord = "public";
  45. private int i = 1;
  46. private Handler handler;
  47. private MqttClient client;
  48. private String myTopic = "test/topic";
  49. private MqttConnectOptions options;
  50. private ScheduledExecutorService scheduler;
  51. @Override
  52. protected void onCreate(Bundle savedInstanceState) {
  53. super.onCreate(savedInstanceState);
  54. init();
  55. setContentView(R.layout.activity_main);
  56. Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
  57. setSupportActionBar(toolbar);
  58. FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
  59. fab.setOnClickListener(new View.OnClickListener() {
  60. @Override
  61. public void onClick(View view) {
  62. Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
  63. .setAction("Action", null).show();
  64. }
  65. });
  66.  
  67. DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
  68. ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
  69. this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
  70. drawer.addDrawerListener(toggle);
  71. toggle.syncState();
  72. NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);
  73. navigationView.setNavigationItemSelectedListener(this);
  74. handler = new Handler(){
  75. @Override
  76. public void handleMessage(Message msg) {
  77. super.handleMessage(msg);
  78. if (msg.what == 1) {
  79. Toast.makeText(MainActivity.this, (String) msg.obj,
  80. Toast.LENGTH_SHORT).show();
  81. } else if (msg.what == 2) {
  82. System.out.println("连接成功");
  83. Toast.makeText(MainActivity.this, "连接成功", Toast.LENGTH_SHORT).show();
  84. try {
  85. client.subscribe(myTopic, 1);
  86. } catch (Exception e) {
  87. e.printStackTrace();
  88. }
  89. } else if (msg.what == 3) {
  90. Toast.makeText(MainActivity.this, "连接失败,系统正在重连", Toast.LENGTH_SHORT).show();
  91. System.out.println("连接失败,系统正在重连");
  92. }
  93. }
  94.  
  95. };
  96.  
  97. startReconnect();
  98. }
  99.  
  100. private void startReconnect() {
  101. scheduler = Executors.newSingleThreadScheduledExecutor();
  102. scheduler.scheduleAtFixedRate(new Runnable() {
  103.  
  104. @Override
  105. public void run() {
  106. if (!client.isConnected()) {
  107. connect();
  108. }
  109. }
  110. }, 0 * 1000, 10 * 1000, TimeUnit.MILLISECONDS);
  111. }
  112.  
  113. private void init() {
  114. try {
  115. //host为主机名,test为clientid即连接MQTT的客户端ID,一般以客户端唯一标识符表示,MemoryPersistence设置clientid的保存形式,默认为以内存保存
  116. client = new MqttClient(host, "test",
  117. new MemoryPersistence());
  118. //MQTT的连接设置
  119. options = new MqttConnectOptions();
  120. //设置是否清空session,这里如果设置为false表示服务器会保留客户端的连接记录,这里设置为true表示每次连接到服务器都以新的身份连接
  121. options.setCleanSession(true);
  122. //设置连接的用户名
  123. options.setUserName(userName);
  124. //设置连接的密码
  125. options.setPassword(passWord.toCharArray());
  126. // 设置超时时间 单位为秒
  127. options.setConnectionTimeout(10);
  128. // 设置会话心跳时间 单位为秒 服务器会每隔1.5*20秒的时间向客户端发送个消息判断客户端是否在线,但这个方法并没有重连的机制
  129. options.setKeepAliveInterval(20);
  130. //设置回调
  131. client.setCallback(new MqttCallback() {
  132. @Override
  133. public void connectionLost(Throwable cause) {
  134. //连接丢失后,一般在这里面进行重连
  135. System.out.println("connectionLost----------");
  136. }
  137. @Override
  138. public void deliveryComplete(IMqttDeliveryToken token) {
  139. //publish后会执行到这里
  140. System.out.println("deliveryComplete---------"
  141. + token.isComplete());
  142. }
  143. @Override
  144. public void messageArrived(String topicName, MqttMessage message)
  145. throws Exception {
  146. //subscribe后得到的消息会执行到这里面
  147. System.out.println("messageArrived----------");
  148. Message msg = new Message();
  149. msg.what = 1;
  150. msg.obj = topicName + "---" + message.toString();
  151. handler.sendMessage(msg);
  152. }
  153. });
  154. } catch (Exception e) {
  155. e.printStackTrace();
  156. }
  157. }
  158. private void connect() {
  159. new Thread(new Runnable() {
  160.  
  161. @Override
  162. public void run() {
  163. try {
  164. client.connect(options);
  165. Message msg = new Message();
  166. msg.what = 2;
  167. handler.sendMessage(msg);
  168. } catch (Exception e) {
  169. e.printStackTrace();
  170. Message msg = new Message();
  171. msg.what = 3;
  172. handler.sendMessage(msg);
  173. }
  174. }
  175. }).start();
  176. }
  177. @Override
  178. public boolean onKeyDown(int keyCode, KeyEvent event) {
  179. if (client != null && keyCode == KeyEvent.KEYCODE_BACK) {
  180. try {
  181. client.disconnect();
  182. } catch (Exception e) {
  183. e.printStackTrace();
  184. }
  185. }
  186. return super.onKeyDown(keyCode, event);
  187. }
  188.  
  189. @Override
  190. protected void onDestroy() {
  191. super.onDestroy();
  192. try {
  193. scheduler.shutdown();
  194. client.disconnect();
  195. } catch (MqttException e) {
  196. e.printStackTrace();
  197. }
  198. }
  199. @Override
  200. public void onBackPressed() {
  201. DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
  202. if (drawer.isDrawerOpen(GravityCompat.START)) {
  203. drawer.closeDrawer(GravityCompat.START);
  204. } else {
  205. super.onBackPressed();
  206. }
  207. }
  208.  
  209. @Override
  210. public boolean onCreateOptionsMenu(Menu menu) {
  211. // Inflate the menu; this adds items to the action bar if it is present.
  212. getMenuInflater().inflate(R.menu.main, menu);
  213. return true;
  214. }
  215.  
  216. @Override
  217. public boolean onOptionsItemSelected(MenuItem item) {
  218. // Handle action bar item clicks here. The action bar will
  219. // automatically handle clicks on the Home/Up button, so long
  220. // as you specify a parent activity in AndroidManifest.xml.
  221. int id = item.getItemId();
  222.  
  223. //noinspection SimplifiableIfStatement
  224. if (id == R.id.action_settings) {
  225. return true;
  226. }
  227.  
  228. return super.onOptionsItemSelected(item);
  229. }
  230.  
  231. @SuppressWarnings("StatementWithEmptyBody")
  232. @Override
  233. public boolean onNavigationItemSelected(MenuItem item) {
  234. // Handle navigation view item clicks here.
  235. int id = item.getItemId();
  236.  
  237. if (id == R.id.nav_camera) {
  238. connect();
  239. } else if (id == R.id.nav_gallery) {
  240.  
  241. } else if (id == R.id.nav_slideshow) {
  242.  
  243. } else if (id == R.id.nav_manage) {
  244.  
  245. } else if (id == R.id.nav_share) {
  246.  
  247. } else if (id == R.id.nav_send) {
  248.  
  249. }
  250.  
  251. DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
  252. drawer.closeDrawer(GravityCompat.START);
  253. return true;
  254. }
  255. }

android studio MQTT测试成功的更多相关文章

  1. Android studio 搭建测试环境 创建虚拟机

    1.打开android studio2.0 ,选择AVD Manger 2.选择Create Virtual Device 3.在左侧Category中选择Phone,然后选择自己喜欢的手机型号,点击 ...

  2. Android Studio 使用技巧

    1.导入Android Studio 工程的一些技巧 因为Gradle版本的问题,我们在使用AS导入工程的时候,经常会碰到本地没有该项目的Gradle版本,这时候AS就会去下载这个版本的Gradle, ...

  3. Windows环境下Android Studio v1.0安装教程

    Windows环境下Android Studio v1.0安装教程 准备工具 JDK安装包. 要求:JDK 7以及以上版本. Android Studio安装文件. Windows: exe(包含SD ...

  4. Mac系统下,在android studio中使用Github版本管理

    1.下载并安装github客户端http://git-scm.com/download/ 2.打开android studio,测试github是否使用ok 点击"test",如果 ...

  5. Android笔记——Windows环境下Android Studio v1.0安装教程

    本文主要讲解Windows环境下Android Studio的安装教程,Mac的Android Studio安装与此类似不在赘述,另外友情提示Windows下的SDK与Mac的SDK是通用的,可以直接 ...

  6. Android学习及开发随记1:Android Studio安装配置

    1.本系列仅为个人使用,概不负责.随着时间推移,部分内容可能因为软件更新而出现不能对应的情况. 本文的配置情况,仅针对Android Studio v1.1.0 windows版本 全新安装. Goo ...

  7. 【转】Windows环境下Android Studio v1.0安装教程

    原文网址:http://ask.android-studio.org/?/article/9 http://android-studio.org/index.php/docs/experience/1 ...

  8. android ndk-build 编译静态库libxx.a 以及Android studio openssl 静态库配置(cmake)

    android ndk-build 编译静态库libxx.a 需求场景: 目前有安卓编码好的现在的openssl的两个.a,我们需要调用openssl的函数,并把功能再封装成.a; 这样使用时,在an ...

  9. Android零基础入门第10节:开发IDE大升级,终于迎来了Android Studio

    原文:Android零基础入门第10节:开发IDE大升级,终于迎来了Android Studio 通过前面几期的学习,我们知道了Android的前世今生,也了解了Android的系统架构和应用组件,也 ...

随机推荐

  1. 字符串查找函数(BF)

    //模拟字符串定位函数 // s: abcbbghi // t: ghi // 返回6 #include <iostream> #include <string> #inclu ...

  2. vue开发购物车,解决全选单选问题

    实现全选单选,在vue中无法通过this获取input中的checkbox的checked属性,但是可以通过vue对input的特殊方式v-model来实现对应数据的绑定,同样也可以通过这种方式实现购 ...

  3. MYSQL初级学习笔记八:MySQL中常用的函数!(视频序号:初级_45-50)

    知识点十:MySQL中的函数(45-50) 数学函数: 名称 描述 CEIL() 进一取整 FLOOR() 舍一取整 MOD 取余数(取摸) POWER() 幂运算 ROUND() 四舍五入 TRUN ...

  4. codeforces 459 A. Pashmak and Garden 解题报告

    题目链接:http://codeforces.com/problemset/problem/459/A 题目意思:给出两个点的坐标你,问能否判断是一个正方形,能则输出剩下两点的坐标,不能就输出 -1. ...

  5. Silverlight实用窍门系列:2.Silverlight动态加载外部XML指定地址的WebService---(动态加载外部XML文件中指定的WebService地址)【附带实例源码】

    接上节所讲的,Silverlight可以加载外部的XML文件里面的内容,那么我们可不可以在外部XML里面配置一个WebService地址,并且以此加载这个地址来动态加载WebService呢?这样子就 ...

  6. skynet源码阅读<7>--死循环检测

    在使用skynet开发时,你也许会碰到类似这样的警告:A message from [ :0100000f ] to [ :0100000a ] maybe in an endless loop (v ...

  7. if_test.py

    strings=['xxaa','xuo','fwefxxx','woeuxxfei'] print(strings) #替换方法1 for string in strings: if 'xx' in ...

  8. 依赖倒置原则DIP&控制反转IOC&依赖注入DI

    依赖倒置原则DIP是软件设计里一个重要的设计思想,它规定上层不依赖下层而是共同依赖抽象接口,通常可以是上层提供接口,然后下层实现接口,上下层之间通过接口完全透明交互.这样的好处,上层不会因依赖的下层修 ...

  9. 数据库备份脚本.sh

    #!/bin/bash #auto bakcup mysql db BAK_DIR=/data/backup/mysql/`date +%Y-%m-%d` MYSQL_DB=数据库名 MYSQL_PW ...

  10. python学习笔记5-自定义函数

    1 自定义函数  (1)函数代码块以def关键字开头,然后函数标识符名称和圆括号  (2)任何传入参数和自变量必须放在圆括号中间.圆括号之间可以用于定义参数  (3)函数的第一行语句可以选择性的使用文 ...