From 9e4bd3c3363e2b767dc9efa535f447fcf0bb0ca0 Mon Sep 17 00:00:00 2001
From: whycq <10027870+whycq@user.noreply.gitee.com>
Date: 星期一, 12 八月 2024 09:48:52 +0800
Subject: [PATCH] #

---
 app/src/main/java/com/example/agvcontroller/StartActivity.java             |   41 ++++++++++++++++++++++++++++++++++-------
 app/src/main/java/com/example/agvcontroller/socket/NettyServerHandler.java |   10 ++++++++++
 app/build.gradle                                                           |    1 +
 3 files changed, 45 insertions(+), 7 deletions(-)

diff --git a/app/build.gradle b/app/build.gradle
index e046d9a..ef29b47 100644
--- a/app/build.gradle
+++ b/app/build.gradle
@@ -36,6 +36,7 @@
     testImplementation 'junit:junit:4.13.2'
     androidTestImplementation 'androidx.test.ext:junit:1.1.5'
     androidTestImplementation 'androidx.test.espresso:espresso-core:3.5.1'
+    implementation 'org.greenrobot:eventbus:3.2.0'
 
     implementation 'androidx.recyclerview:recyclerview:1.3.0'
     implementation 'io.netty:netty-all:4.1.68.Final'
diff --git a/app/src/main/java/com/example/agvcontroller/StartActivity.java b/app/src/main/java/com/example/agvcontroller/StartActivity.java
index 0a37be5..6d9fef1 100644
--- a/app/src/main/java/com/example/agvcontroller/StartActivity.java
+++ b/app/src/main/java/com/example/agvcontroller/StartActivity.java
@@ -1,12 +1,17 @@
 package com.example.agvcontroller;
 
 import android.os.Bundle;
+import android.util.Log;
 
 import androidx.appcompat.app.AppCompatActivity;
 import androidx.recyclerview.widget.LinearLayoutManager;
 import androidx.recyclerview.widget.RecyclerView;
 
 import com.example.agvcontroller.socket.SocketManager;
+
+import org.greenrobot.eventbus.EventBus;
+import org.greenrobot.eventbus.Subscribe;
+import org.greenrobot.eventbus.ThreadMode;
 
 import java.util.ArrayList;
 import java.util.List;
@@ -22,19 +27,41 @@
         super.onCreate(savedInstanceState);
         setContentView(R.layout.activity_start);
 
-        socketManager = new SocketManager();
-        socketManager.startServer(8080);
-
         recyclerView = findViewById(R.id.recyclerView);
         recyclerView.setLayoutManager(new LinearLayoutManager(this));
 
         items = new ArrayList<>();
-        //items.add(new Item("192.168.4.188", "Item 1", "Description of Item 1"));
-        //items.add(new Item("192.168.4.61", "Item 2", "Description of Item 2"));
-        //items.add(new Item("192.168.4.233", "Item 3", "Description of Item 3"));
 
         adapter = new ItemAdapter(items);
         recyclerView.setAdapter(adapter);
-        adapter.addItem(new Item("AGV-3948", "192.168.4.188:56487", "Description of Item 1"));
+
+        EventBus.getDefault().register(this);
+
+        socketManager = new SocketManager();
+        socketManager.startServer(8080);
+    }
+
+    @Subscribe(threadMode = ThreadMode.MAIN)
+    public void onDeviceConnected(Item deviceAddress) {
+        Log.i("EventBus", "Received device connected: " + deviceAddress);
+        items.add(new Item("1",deviceAddress.getIp(),"3"));
+        if (items.size() > 0) {
+            for (Item item : items) {
+                Log.i("Item",item.getIp());
+            }
+        }
+        adapter.notifyDataSetChanged();
+    }
+
+    @Subscribe(threadMode = ThreadMode.MAIN)
+    public void onDeviceDisconnected(String deviceIp) {
+        Log.i("EventBus", "Received device disconnected: " + deviceIp);
+        for (int i = 0; i < items.size(); i++) {
+            if (items.get(i).getIp().equals(deviceIp)) {
+                items.remove(i);
+                break;
+            }
+        }
+        adapter.notifyDataSetChanged();
     }
 }
\ No newline at end of file
diff --git a/app/src/main/java/com/example/agvcontroller/socket/NettyServerHandler.java b/app/src/main/java/com/example/agvcontroller/socket/NettyServerHandler.java
index 13abdea..35c77b2 100644
--- a/app/src/main/java/com/example/agvcontroller/socket/NettyServerHandler.java
+++ b/app/src/main/java/com/example/agvcontroller/socket/NettyServerHandler.java
@@ -8,6 +8,14 @@
 import io.netty.channel.ChannelHandlerContext;
 import io.netty.channel.ChannelInboundHandlerAdapter;
 import android.util.Log;
+
+import com.example.agvcontroller.Item;
+
+
+import org.greenrobot.eventbus.EventBus;
+import org.greenrobot.eventbus.Subscribe;
+import org.greenrobot.eventbus.ThreadMode;
+
 import java.util.concurrent.ConcurrentHashMap;
 
 public class NettyServerHandler extends ChannelInboundHandlerAdapter {
@@ -19,6 +27,7 @@
     public void channelActive(ChannelHandlerContext ctx) throws Exception {
         String clientId = ctx.channel().remoteAddress().toString();
         channelMap.put(clientId, ctx.channel());
+        EventBus.getDefault().post(new Item("1",clientId,"3"));
         Log.d(TAG, "Client connected: " + clientId);
     }
 
@@ -26,6 +35,7 @@
     public void channelInactive(ChannelHandlerContext ctx) throws Exception {
         String clientId = ctx.channel().remoteAddress().toString();
         channelMap.remove(clientId);
+        EventBus.getDefault().post(clientId);
         Log.d(TAG, "Client disconnected: " + clientId);
     }
 

--
Gitblit v1.9.1