From 6f1275502e0d7be1b919f9d6eb308436cc8958fa Mon Sep 17 00:00:00 2001
From: whycq <913841844@qq.com>
Date: 星期四, 16 一月 2025 09:22:01 +0800
Subject: [PATCH] #
---
app/src/main/java/com/example/agvcontroller/StartActivity.java | 74 +++++++++++++++++++++++++++++++++---
1 files changed, 67 insertions(+), 7 deletions(-)
diff --git a/app/src/main/java/com/example/agvcontroller/StartActivity.java b/app/src/main/java/com/example/agvcontroller/StartActivity.java
index 5205f98..d8d5a29 100644
--- a/app/src/main/java/com/example/agvcontroller/StartActivity.java
+++ b/app/src/main/java/com/example/agvcontroller/StartActivity.java
@@ -1,10 +1,20 @@
package com.example.agvcontroller;
+import android.content.Context;
+import android.content.Intent;
import android.os.Bundle;
+import android.util.Log;
+import android.view.View;
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;
@@ -13,20 +23,70 @@
private RecyclerView recyclerView;
private List<Item> items;
+ private ItemAdapter adapter;
+ SocketManager socketManager;
@Override
protected void onCreate(Bundle savedInstanceState) {
+
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_start);
+ recyclerView = findViewById(R.id.recyclerView);
+ recyclerView.setLayoutManager(new LinearLayoutManager(this));
- //recyclerView = findViewById(R.id.recyclerView);
- //recyclerView.setLayoutManager(new LinearLayoutManager(this));
- //
- //items = new ArrayList<>();
- //items.add(new Item("192.168", "Item 1", "Description of Item 1"));
- //items.add(new Item("192.168", "Item 2", "Description of Item 2"));
- //items.add(new Item("192.168", "Item 3", "Description of Item 3"));
+ items = new ArrayList<>();
+
+ adapter = new ItemAdapter(items);
+ recyclerView.setAdapter(adapter);
+
+ EventBus.getDefault().register(this);
+
+ adapter.setmOnItemClickListener(new ItemAdapter.OnItemClickListener() {
+
+ @Override
+ public void onItemClick(View view, int position) {
+ Context context = view.getContext();
+ Intent intent = new Intent(context,MainActivity.class);
+ intent.putExtra("ip", items.get(position).getIp());
+ intent.putExtra("agvNo", items.get(position).getAgvNo());
+ startActivityForResult(intent,1);
+ }
+ });
+ socketManager = new SocketManager();
+ socketManager.startServer(8022);
+ }
+
+ @Subscribe(threadMode = ThreadMode.MAIN)
+ public void onDeviceConnected(Item deviceAddress) {
+ Log.i("EventBus", "Received device connected: " + deviceAddress);
+ if (items.size() > 0) {
+ int sameIp = 0;
+ for (Item item : items) {
+ if (item.getIp().equals(deviceAddress.getIp())) {
+ sameIp++;
+ }
+ Log.i("Item",item.getIp());
+ }
+ if (sameIp == 0) {
+ items.add(new Item(deviceAddress.getText(),deviceAddress.getIp(),deviceAddress.getAgvNo()));
+ }
+ } else {
+ items.add(new Item(deviceAddress.getText(),deviceAddress.getIp(),deviceAddress.getAgvNo()));
+ }
+ 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
--
Gitblit v1.9.1