From 318bd727e2fe02e4f541dfe943f77606af41d509 Mon Sep 17 00:00:00 2001
From: whycq <913841844@qq.com>
Date: 星期四, 06 二月 2025 14:30:11 +0800
Subject: [PATCH] #

---
 app/src/main/java/com/example/agvcontroller/MainActivity.java |  822 +++++++++++++++++++++++++++++++++++-----------------------
 1 files changed, 498 insertions(+), 324 deletions(-)

diff --git a/app/src/main/java/com/example/agvcontroller/MainActivity.java b/app/src/main/java/com/example/agvcontroller/MainActivity.java
index 5e68826..33187b5 100644
--- a/app/src/main/java/com/example/agvcontroller/MainActivity.java
+++ b/app/src/main/java/com/example/agvcontroller/MainActivity.java
@@ -7,10 +7,9 @@
 
 import android.content.Context;
 import android.content.Intent;
-import android.content.res.ColorStateList;
-import android.graphics.Color;
 import android.os.Bundle;
 import android.os.Handler;
+import android.os.Looper;
 import android.os.Message;
 import android.os.Vibrator;
 import android.util.Log;
@@ -22,6 +21,7 @@
 import android.widget.GridLayout;
 import android.widget.RelativeLayout;
 import android.widget.Switch;
+import android.widget.TextView;
 
 import com.example.agvcontroller.action.AllResetAction;
 import com.example.agvcontroller.action.BackPaddle;
@@ -46,7 +46,12 @@
 import com.example.agvcontroller.utils.DialogUtil;
 import com.example.agvcontroller.utils.SnowflakeIdWorker;
 
+import org.greenrobot.eventbus.EventBus;
+import org.greenrobot.eventbus.Subscribe;
+import org.greenrobot.eventbus.ThreadMode;
+
 import java.net.Socket;
+import java.util.ArrayList;
 import java.util.List;
 import java.util.Map;
 import java.util.concurrent.ConcurrentHashMap;
@@ -57,9 +62,24 @@
     public static final Map<String, Object> map = new ConcurrentHashMap();
     public static final Map<String, Object> car_num = new ConcurrentHashMap();
 
-    private RecyclerView recyclerView;
-    private ItemAdapter itemAdapter;
-    private List<Item> itemList;
+    private static TextView recentLogTextView;
+    private static Handler mainHandler;
+    private static List<String> logList = AGVApplication.getLogList();
+    private static final int MAX_RECENT_LOGS = 10; // 鏈�澶氭樉绀� 10 鏉℃渶鏂版棩蹇�
+
+    private static TextView agvBattery;
+    private static TextView agvNo;
+    private static TextView agvStatus;
+    private static TextView agvPositionId;
+    private static TextView agvPositionX;
+    private static TextView agvPositionY;
+    private static TextView agvForkHeight;
+    private static TextView agvForkExtend;
+    private static TextView agvForkAngle;
+    private static TextView agvError;
+
+
+
     private Vibrator vibrator;
     private Button stopBtn;  // 鎬ュ仠鎸夐挳
 //    private Button forceSwitchBtn;  // 鎵嬭嚜鍔ㄥ己鍒跺紑鍏�
@@ -116,11 +136,13 @@
     private Button axleFrontBtn9;
     private Button axleBackBtn9;
 
+    private Button viewAllLogsButton;
+
 
 
     private Button bodySwitchBtn; // 搴曠洏/璐у弶鍒囨崲
     private Socket socket;
-    private String AgvNo = "1";
+
     private RelativeLayout layout_bottom;
     private RelativeLayout layout_top;
     private GridLayout layout_single;
@@ -168,13 +190,14 @@
         @Override
         public boolean handleMessage(Message msg) {
             String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-            short pwd = 0;
             if (isGoForward) {
+                Log.d(TAG, "isGoForward: " + isGoForward);
                 AgvAction agvAction = new AgvAction<>(ForwardBackAction.class)
                         .setAgvNo(AgvNo)
                         .setSerialNo(substring)
                         .setVal(1)
                         .bodySync((action) -> action.setPwd((short) 50));
+                Log.d(TAG, "isGoForward: " + clientId);
                 nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
                 handler.sendEmptyMessageDelayed(0, 100);  //  100ms 鍚庡彂閫佷笅涓�鏉℃秷鎭�
             }
@@ -206,35 +229,196 @@
                 handler.sendEmptyMessageDelayed(0, 100);
             }
 
-            if (isRotatopnRight) {
-                AgvAction agvAction = new AgvAction<>(RotatopnLeftRight.class)
+            if (isFront1) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
                         .setAgvNo(AgvNo)
                         .setSerialNo(substring)
                         .setVal(1)
-                        .bodySync((action) -> action.setPwd((short) 50));
+                        .bodySync((action) -> action.setPwd((short) 99));
                 nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
                 handler.sendEmptyMessageDelayed(0, 100);
             }
-            if (isRotatopnLeft) {
-                AgvAction agvAction = new AgvAction<>(RotatopnLeftRight.class)
+            if (isBack1) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
                         .setAgvNo(AgvNo)
                         .setSerialNo(substring)
                         .setVal(1)
-                        .bodySync((action) -> action.setPwd((short) -50 ));
+                        .bodySync((action) -> action.setPwd((short) -99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isFront2) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(2)
+                        .bodySync((action) -> action.setPwd((short) 99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isBack2) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(2)
+                        .bodySync((action) -> action.setPwd((short) -99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isFront3) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(3)
+                        .bodySync((action) -> action.setPwd((short) 99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isBack3) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(3)
+                        .bodySync((action) -> action.setPwd((short) -99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isFront4) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(4)
+                        .bodySync((action) -> action.setPwd((short) 99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isBack4) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(4)
+                        .bodySync((action) -> action.setPwd((short) -99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isFront5) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(5)
+                        .bodySync((action) -> action.setPwd((short) 99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isBack5) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(5)
+                        .bodySync((action) -> action.setPwd((short) -99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isFront6) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(6)
+                        .bodySync((action) -> action.setPwd((short) 99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isBack6) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(6)
+                        .bodySync((action) -> action.setPwd((short) -99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isFront7) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(7)
+                        .bodySync((action) -> action.setPwd((short) 99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isBack7) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(7)
+                        .bodySync((action) -> action.setPwd((short) -99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isFront8) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(8)
+                        .bodySync((action) -> action.setPwd((short) 99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isBack8) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(8)
+                        .bodySync((action) -> action.setPwd((short) -99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isFront9) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(9)
+                        .bodySync((action) -> action.setPwd((short) 99));
+                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                handler.sendEmptyMessageDelayed(0, 100);
+            }
+            if (isBack9) {
+                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
+                        .setAgvNo(AgvNo)
+                        .setSerialNo(substring)
+                        .setVal(9)
+                        .bodySync((action) -> action.setPwd((short) -99));
                 nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
                 handler.sendEmptyMessageDelayed(0, 100);
             }
             return false;
         }
     });
-
-    String clientId;
+    static String AgvNo = "1";
+    static String clientId;
     NettyServerHandler nettyServerHandler;
+
+
 
     @Override
     protected void onCreate(Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
         setContentView(R.layout.activity_main);
+
+        agvBattery = findViewById(R.id.agv_battery);
+        agvNo = findViewById(R.id.agv_no);
+        agvStatus = findViewById(R.id.agv_status);
+        agvPositionId = findViewById(R.id.agv_position_id);
+        agvPositionX = findViewById(R.id.agv_position_x);
+        agvPositionY = findViewById(R.id.agv_position_y);
+        agvForkHeight = findViewById(R.id.agv_position_height);
+        agvForkExtend = findViewById(R.id.agv_ford);
+        agvForkAngle = findViewById(R.id.agv_ratio);
+        agvError = findViewById(R.id.agv_error);
+
+
+
+
 
         // 鎸夐挳闇囧姩
         vibrator = (Vibrator) getSystemService(Context.VIBRATOR_SERVICE);
@@ -303,11 +487,41 @@
         liftResetBtn = findViewById(R.id.btn_lift_reset);
         allResetBtn = findViewById(R.id.btn_all_reset);
 
+        viewAllLogsButton = findViewById(R.id.view_all_logs_button);
+        recentLogTextView = findViewById(R.id.recent_log_text_view);
+        mainHandler = new Handler(Looper.getMainLooper());
+
+        // 鍒濆鍖栨棩蹇楁樉绀�
+        updateRecentLogTextView();
+
+        // 鍚姩涓�涓畾鏃朵换鍔℃潵瀹氭湡妫�鏌ユ棩蹇楀垪琛ㄧ殑鍙樺寲
+        handler.postDelayed(new Runnable() {
+            @Override
+            public void run() {
+                updateLogDisplay();
+                handler.postDelayed(this, 1000); // 姣忕妫�鏌ヤ竴娆�
+            }
+        }, 100);
+
+        // 娉ㄥ唽 EventBus
+        EventBus.getDefault().register(this);
+
+        // 璁剧疆鏌ョ湅鍏ㄩ儴鏃ュ織鎸夐挳鐨勭偣鍑讳簨浠�
+        viewAllLogsButton.setOnClickListener(new View.OnClickListener() {
+            @Override
+            public void onClick(View v) {
+                showAllLogsActivity();
+            }
+        });
 
 
         Intent intent = getIntent();
-        clientId = intent.getStringExtra("ip");
-        AgvNo = intent.getStringExtra("agvNo");
+        if (intent != null) {
+            AGVCar car = (AGVCar) intent.getSerializableExtra("item");
+            clientId = car.getClientId();
+            AgvNo = car.getAgvNo();
+        }
+
         Log.i("message1",clientId);
 
         // 鍓嶆嫧鏉嗕几鍑�
@@ -690,7 +904,7 @@
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(1)
-                            .bodySync((action) -> action.setPwd((short) 0));
+                            .bodySync((action) -> action.setPwd((short) 1));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
                     axleFrontBtn1.setVisibility(View.VISIBLE);
                     axleBackBtn1.setVisibility(View.VISIBLE);
@@ -699,7 +913,7 @@
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(1)
-                            .bodySync((action) -> action.setPwd((short) 1));
+                            .bodySync((action) -> action.setPwd((short) 0));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
                     axleFrontBtn1.setVisibility(View.GONE);
                     axleBackBtn1.setVisibility(View.GONE);
@@ -720,15 +934,19 @@
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(2)
-                            .bodySync((action) -> action.setPwd((short) 0));
+                            .bodySync((action) -> action.setPwd((short) 1));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn2.setVisibility(View.VISIBLE);
+                    axleBackBtn2.setVisibility(View.VISIBLE);
                 } else {
                     AgvAction agvAction = new AgvAction<>(SingleSwitchAction.class)
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(2)
-                            .bodySync((action) -> action.setPwd((short) 1));
+                            .bodySync((action) -> action.setPwd((short) 0));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn2.setVisibility(View.GONE);
+                    axleBackBtn2.setVisibility(View.GONE);
                 }
             }
         });
@@ -746,15 +964,19 @@
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(3)
-                            .bodySync((action) -> action.setPwd((short) 0));
+                            .bodySync((action) -> action.setPwd((short) 1));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn3.setVisibility(View.VISIBLE);
+                    axleBackBtn3.setVisibility(View.VISIBLE);
                 } else {
                     AgvAction agvAction = new AgvAction<>(SingleSwitchAction.class)
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(3)
-                            .bodySync((action) -> action.setPwd((short) 1));
+                            .bodySync((action) -> action.setPwd((short) 0));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn3.setVisibility(View.GONE);
+                    axleBackBtn3.setVisibility(View.GONE);
                 }
             }
         });
@@ -772,15 +994,19 @@
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(4)
-                            .bodySync((action) -> action.setPwd((short) 0));
+                            .bodySync((action) -> action.setPwd((short) 1));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn4.setVisibility(View.VISIBLE);
+                    axleBackBtn4.setVisibility(View.VISIBLE);
                 } else {
                     AgvAction agvAction = new AgvAction<>(SingleSwitchAction.class)
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(4)
-                            .bodySync((action) -> action.setPwd((short) 1));
+                            .bodySync((action) -> action.setPwd((short) 0));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn4.setVisibility(View.GONE);
+                    axleBackBtn4.setVisibility(View.GONE);
                 }
             }
         });
@@ -828,15 +1054,19 @@
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(6)
-                            .bodySync((action) -> action.setPwd((short) 0));
+                            .bodySync((action) -> action.setPwd((short) 1));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn6.setVisibility(View.VISIBLE);
+                    axleBackBtn6.setVisibility(View.VISIBLE);
                 } else {
                     AgvAction agvAction = new AgvAction<>(SingleSwitchAction.class)
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(6)
-                            .bodySync((action) -> action.setPwd((short) 1));
+                            .bodySync((action) -> action.setPwd((short) 0));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn6.setVisibility(View.GONE);
+                    axleBackBtn6.setVisibility(View.GONE);
                 }
             }
         });
@@ -854,15 +1084,19 @@
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(7)
-                            .bodySync((action) -> action.setPwd((short) 0));
+                            .bodySync((action) -> action.setPwd((short) 1));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn7.setVisibility(View.VISIBLE);
+                    axleBackBtn7.setVisibility(View.VISIBLE);
                 } else {
                     AgvAction agvAction = new AgvAction<>(SingleSwitchAction.class)
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(7)
-                            .bodySync((action) -> action.setPwd((short) 1));
+                            .bodySync((action) -> action.setPwd((short) 0));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn7.setVisibility(View.GONE);
+                    axleBackBtn7.setVisibility(View.GONE);
                 }
             }
         });
@@ -880,15 +1114,19 @@
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(8)
-                            .bodySync((action) -> action.setPwd((short) 0));
+                            .bodySync((action) -> action.setPwd((short) 1));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn8.setVisibility(View.VISIBLE);
+                    axleBackBtn8.setVisibility(View.VISIBLE);
                 } else {
                     AgvAction agvAction = new AgvAction<>(SingleSwitchAction.class)
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(8)
-                            .bodySync((action) -> action.setPwd((short) 1));
+                            .bodySync((action) -> action.setPwd((short) 0));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn8.setVisibility(View.GONE);
+                    axleBackBtn8.setVisibility(View.GONE);
                 }
             }
         });
@@ -906,307 +1144,23 @@
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(9)
-                            .bodySync((action) -> action.setPwd((short) 0));
+                            .bodySync((action) -> action.setPwd((short) 1));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn9.setVisibility(View.VISIBLE);
+                    axleBackBtn9.setVisibility(View.VISIBLE);
                 } else {
                     AgvAction agvAction = new AgvAction<>(SingleSwitchAction.class)
                             .setAgvNo(AgvNo)
                             .setSerialNo(substring)
                             .setVal(9)
-                            .bodySync((action) -> action.setPwd((short) 1));
+                            .bodySync((action) -> action.setPwd((short) 0));
                     nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
+                    axleFrontBtn9.setVisibility(View.GONE);
+                    axleBackBtn9.setVisibility(View.GONE);
                 }
             }
         });
 
-
-        axleFrontBtn1.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(1)
-                        .bodySync((action) -> action.setPwd((short) 100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleBackBtn1.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(1)
-                        .bodySync((action) -> action.setPwd((short) -100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleFrontBtn2.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(2)
-                        .bodySync((action) -> action.setPwd((short) 100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleBackBtn2.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(2)
-                        .bodySync((action) -> action.setPwd((short) -100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleFrontBtn3.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(3)
-                        .bodySync((action) -> action.setPwd((short) 100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleBackBtn3.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(3)
-                        .bodySync((action) -> action.setPwd((short) -100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleFrontBtn4.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(4)
-                        .bodySync((action) -> action.setPwd((short) 100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleBackBtn4.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(4)
-                        .bodySync((action) -> action.setPwd((short) -100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleFrontBtn5.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(5)
-                        .bodySync((action) -> action.setPwd((short) 99));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleBackBtn5.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(5)
-                        .bodySync((action) -> action.setPwd((short) -99));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleFrontBtn6.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(6)
-                        .bodySync((action) -> action.setPwd((short) 100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleBackBtn6.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(6)
-                        .bodySync((action) -> action.setPwd((short) -100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleFrontBtn7.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(7)
-                        .bodySync((action) -> action.setPwd((short) 100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleBackBtn7.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(7)
-                        .bodySync((action) -> action.setPwd((short) -100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleFrontBtn8.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(8)
-                        .bodySync((action) -> action.setPwd((short) 100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleBackBtn8.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(8)
-                        .bodySync((action) -> action.setPwd((short) -100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleFrontBtn9.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(9)
-                        .bodySync((action) -> action.setPwd((short) 100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
-
-        axleBackBtn9.setOnClickListener(new View.OnClickListener(){
-            @Override
-            public void onClick(View v) {
-                if (vibrator != null && vibrator.hasVibrator()) {
-                    vibrator.vibrate(500);
-                }
-                String substring = String.valueOf(new SnowflakeIdWorker().nextId()).substring(0,16);
-                AgvAction agvAction = new AgvAction<>(SingleSwitchRunAction.class)
-                        .setAgvNo(AgvNo)
-                        .setSerialNo(substring)
-                        .setVal(9)
-                        .bodySync((action) -> action.setPwd((short) -100));
-                nettyServerHandler.sendMessageToClient(clientId, agvAction); // 鍙戦�佹秷鎭埌瀹㈡埛绔�
-            }
-        });
 
         // 鐐瑰姩鎸夐挳
         stopBtn.setOnTouchListener(new CarTouchButton());
@@ -1236,6 +1190,25 @@
 
 
     }
+
+    private void updateLogDisplay() {
+        // 鑾峰彇鏈�鏂扮殑鏃ュ織鍒楄〃
+        List<String> logs = AGVApplication.getLogList();
+        // 鑾峰彇鏈�鍚庝袱鏉℃棩蹇�
+        int size = logs.size();
+        if (size == 0) {
+            recentLogTextView.setText("");
+        } else if (size == 1) {
+            recentLogTextView.setText(logs.get(0));
+        } else {
+            String logText = logs.get(size - 2) + "\n" + // 鑾峰彇鍊掓暟绗簩鏉℃棩蹇�
+                    logs.get(size - 1); // 鑾峰彇鏈�鍚庝竴鏉℃棩蹇�
+            // 鏇存柊 TextView 鐨勬樉绀哄唴瀹�
+            Log.d("logs", "updateLogDisplay: " + logText);
+            recentLogTextView.setText(logText);
+        }
+    }
+
 
     private class CarTouchButton implements View.OnTouchListener {
 
@@ -1275,15 +1248,152 @@
                 } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
                     isRotatopnRight = false;
                 }
-            } else if (view.getId() == R.id.btn_rotatopn_right) {
+            } else if (view.getId() == R.id.btn_axle_1_front) {
                 // 杞村姩鎸夐挳
                 if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
-                    isRotatopnRight = true;
+                    isFront1 = true;
                     handler.sendEmptyMessage(0);
                 } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
-                    isRotatopnRight = false;
+                    isFront1 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_1_back) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isBack1 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isBack1 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_2_front) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isFront2 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isFront2 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_2_back) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isBack2 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isBack2 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_3_front) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isFront3 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isFront3 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_3_back) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isBack3 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isBack3 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_4_front) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isFront4 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isFront4 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_4_back) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isBack4 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isBack4 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_5_front) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isFront5 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isFront5 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_5_back) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isBack5 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isBack5 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_6_front) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isFront6 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isFront6 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_6_back) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isBack6 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isBack6 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_7_front) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isFront7 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isFront7 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_7_back) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isBack7 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isBack7 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_8_front) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isFront8 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isFront8 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_8_back) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isBack8 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isBack8 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_9_front) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isFront9 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isFront9 = false;
+                }
+            } else if (view.getId() == R.id.btn_axle_9_back) {
+                // 杞村姩鎸夐挳
+                if (motionEvent.getAction() == KeyEvent.ACTION_DOWN) {
+                    isBack9 = true;
+                    handler.sendEmptyMessage(0);
+                } else if (motionEvent.getAction() == KeyEvent.ACTION_UP) {
+                    isBack9 = false;
                 }
             }
+
 
 
             return false;
@@ -1333,5 +1443,69 @@
         //SocketManager.getInstance().disconnect();
         //SocketManager.getInstance().stopServer();
         //socketManager.stopServer(); // 鍋滄鏈嶅姟鍣�
+        // 绉婚櫎瀹氭椂浠诲姟锛岄伩鍏嶅唴瀛樻硠婕�
+        handler.removeCallbacksAndMessages(null);
+    }
+
+
+
+
+
+
+
+
+
+    public static void upClient(AGVCar agvCar) {
+        clientId = agvCar.getClientId();
+        AgvNo = agvCar.getAgvNo();
+        agvNo.setText("AGV缂栧彿锛�" + AgvNo);
+        agvBattery.setText("鐢甸噺锛�" + agvCar.getBattery() + "%");
+        agvStatus.setText("AGV鐘舵�侊細" + agvCar.getStatus());
+        agvPositionId.setText("ID锛�" + agvCar.getPositionID());
+        agvPositionX.setText("(X)锛�" + agvCar.getPositionX());
+        agvPositionY.setText("(Y)锛�" + agvCar.getPositionY());
+        agvForkHeight.setText("褰撳墠楂樺害锛�" + agvCar.getForkHeight() + "mm");
+        agvForkExtend.setText("璐у弶浼稿嚭璺濈锛�" + agvCar.getForkExtend() + "mm");
+        agvForkAngle.setText("璐у弶鏃嬭浆瑙掑害锛�" + agvCar.getForkAngle() + "掳");
+        agvError.setText("AGV鏁呴殰锛�" + agvCar.getAgvError());
+//        updateAgvBatteryText("鐢甸噺锛�" + agvCar.getBattery() + "%");
+    }
+
+    private static void updateAgvBatteryText(String batteryLevel) {
+        if (agvBattery != null) {
+            agvBattery.setText(batteryLevel);
+        }
+    }
+
+    // EventBus 璁㈤槄鏂规硶锛氭帴鏀舵棩蹇楀瓧绗︿覆
+    @Subscribe(threadMode = ThreadMode.MAIN)
+    public void onLogMessageReceived(String logMessage) {
+        addLog(logMessage);
+    }
+    // 鏂规硶锛氭洿鏂版渶杩戠殑鏃ュ織鏄剧ず
+    public static void updateRecentLogTextView() {
+        mainHandler.post(new Runnable() {
+            @Override
+            public void run() {
+                StringBuilder logBuilder = new StringBuilder();
+                int start = Math.max(0, logList.size() - MAX_RECENT_LOGS);
+                for (int i = start; i < logList.size(); i++) {
+                    logBuilder.append(logList.get(i)).append("\n");
+                }
+                recentLogTextView.setText(logBuilder.toString());
+            }
+        });
+    }
+    // 闈欐�佹柟娉曪細娣诲姞鏃ュ織
+    public static void addLog(String log) {
+        logList.add(log);
+        updateRecentLogTextView();
+    }
+
+    // 鏂规硶锛氬惎鍔� LogActivity 骞朵紶閫掓棩蹇楁暟鎹�
+    private void showAllLogsActivity() {
+        Intent intent = new Intent(this, LogActivity.class);
+        intent.putStringArrayListExtra("log_list", new ArrayList<>(logList));
+        startActivity(intent);
     }
 }
\ No newline at end of file

--
Gitblit v1.9.1