安卓基础(点击项目)

代码集合

从数据库把记录好的组件放入组件Arraylist里面(units)

设置units和监听器在unitAdapter适配器里面

unitAdapter.notifyDataSetChanged(); 更新

java 复制代码
import com.example.mobileagent.model.RecordedUnit;
import com.example.mobileagent.adapter.UnitAdapter;
 
private List<RecordedUnit> units = new ArrayList<>();
private List<Object> components = new ArrayList<>();


        // 设置单元列表
        unitAdapter = new UnitAdapter(this, units, unit -> addUnitToWorkflow(unit));
        rvUnits.setLayoutManager(new LinearLayoutManager(this, LinearLayoutManager.HORIZONTAL, false));
        rvUnits.setAdapter(unitAdapter);


        units.clear();
        List<RecordedUnit> loadedUnits = dbHelper.getAllRecordedUnits();
        if (loadedUnits != null) {
            units.addAll(loadedUnits);
        }
        unitAdapter.notifyDataSetChanged();

    private void addUnitToWorkflow(RecordedUnit unit) {
        components.add(unit);
        componentAdapter.notifyItemInserted(components.size() - 1);
        Toast.makeText(this, "已添加单元: " + unit.getTitle(), Toast.LENGTH_SHORT).show();
    }

适配器

把RecyclerView.Adapter继承在UnitAdapter里面

类里有静态类static class UnitViewHolder extends RecyclerView.ViewHolder

java 复制代码
package com.example.mobileagent.adapter;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;

import com.example.mobileagent.R;
import com.example.mobileagent.model.RecordedUnit;

import java.util.List;

public class UnitAdapter extends RecyclerView.Adapter<UnitAdapter.UnitViewHolder> {
    
    public interface OnItemClickListener {
        void onItemClick(RecordedUnit unit);
    }
    
    private final Context context;
    private final List<RecordedUnit> units;
    private final OnItemClickListener listener;
    
    public UnitAdapter(Context context, List<RecordedUnit> units, OnItemClickListener listener) {
        this.context = context;
        this.units = units;
        this.listener = listener;
    }
    
    @NonNull
    @Override
    public UnitViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(context).inflate(R.layout.item_unit, parent, false);
        return new UnitViewHolder(view);
    }
    
    @Override
    public void onBindViewHolder(@NonNull UnitViewHolder holder, int position) {
        RecordedUnit unit = units.get(position);
        holder.bind(unit, listener);
    }
    
    @Override
    public int getItemCount() {
        return units.size();
    }
    
    static class UnitViewHolder extends RecyclerView.ViewHolder {
        private final TextView titleText;
        private final TextView coordinatesText;
        
        public UnitViewHolder(@NonNull View itemView) {
            super(itemView);
            titleText = itemView.findViewById(R.id.tvUnitTitle);
            coordinatesText = itemView.findViewById(R.id.tvCoordinates);
        }
        
        public void bind(RecordedUnit unit, OnItemClickListener listener) {
            titleText.setText(unit.getTitle());
            coordinatesText.setText(String.format("X=%.1f, Y=%.1f", unit.getX(), unit.getY()));
            
            itemView.setOnClickListener(v -> {
                if (listener != null) {
                    listener.onItemClick(unit);
                }
            });
        }
    }
} 

xml

XML 复制代码
<?xml version="1.0" encoding="utf-8"?>
<androidx.cardview.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="150dp"
    android:layout_height="match_parent"
    android:layout_margin="4dp"
    app:cardCornerRadius="8dp"
    app:cardElevation="2dp"
    app:cardBackgroundColor="#E8F5E9">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        android:padding="8dp"
        android:gravity="center">

        <TextView
            android:id="@+id/tvUnitTitle"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="单元标题"
            android:textSize="16sp"
            android:textStyle="bold"
            android:maxLines="1"
            android:ellipsize="end"
            android:gravity="center"
            android:textColor="#333333"
            android:layout_marginBottom="8dp"/>

        <TextView
            android:id="@+id/tvCoordinates"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="X=0, Y=0"
            android:textSize="14sp"
            android:textColor="#333333"
            android:gravity="center"/>

        <TextView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="点击添加"
            android:textSize="12sp"
            android:textColor="#0066CC"
            android:gravity="center"
            android:layout_marginTop="8dp"/>

    </LinearLayout>

</androidx.cardview.widget.CardView> 
相关推荐
游戏开发爱好者82 小时前
iOS 26 iPhone 使用记录分析 多工具组合构建全方位设备行为洞察体系
android·ios·小程序·uni-app·cocoa·iphone·webview
zhangphil9 小时前
HARDWARE 属性的Bitmap与普通Bitmap,GPU与RenderThread渲染与处理方式异同比较,Android
android
消失的旧时光-194310 小时前
Flutter 异步编程:Future 与 Stream 深度解析
android·前端·flutter
黑夜路人11 小时前
Claude Code + 国产模型GLM-4.6 安装指南 (for Windows/Mac)
windows·macos
nono牛11 小时前
Linux基础指令大全(快速上手)
linux·服务器·windows·智能手机
alexhilton11 小时前
Compose CameraX现已稳定:给Composer的端到端指南
android·kotlin·android jetpack
阿里云云原生13 小时前
移动端性能监控探索:可观测 Android 采集探针架构与实现
android
雨白13 小时前
玩转 Flow 操作符(一):数据转换与过滤
android·kotlin
二流小码农13 小时前
鸿蒙开发:web页面如何适配深色模式
android·ios·harmonyos
安当加密14 小时前
如何通过掌纹识别实现Windows工作站安全登录:从技术原理到企业级落地实践
windows·安全·1024程序员节