RecyclerView

package com.ali.recyclerviewdemo;


public class MainActivity extends AppCompatActivity {


    private RecyclerView recyClerView;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        recyClerView = findViewById(R.id.main_recycler);
        Observable<Bean> login=RetrofitManager.getDefault().create(MainApi.class).login();
        //被观察者在子线程处理数据
        login.subscribeOn(Schedulers.io())
               // 子线程
                .observeOn(AndroidSchedulers.mainThread())
                //
                .subscribe(new Consumer<Bean>() {

                    private List<Bean.DataBean> data;

                    @Override
                    public void accept(Bean bean) throws Exception {
                        data = bean.getData();
                        //
                        final MyAdapter myAdapter = new MyAdapter(data,MainActivity.this);
                        LinearLayoutManager linearLayoutManager = new LinearLayoutManager(MainActivity.this);
                        recyClerView.setLayoutManager(linearLayoutManager);
                        recyClerView.setAdapter(myAdapter);
                    }
                });
    }
}

 

 

 

 

package com.ali.recyclerviewdemo;


public class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyViewHolder> {

   private List<Bean.DataBean> data;
   private Context  context;

   //public Context context;
    //public MyAdapter(List<Bean.DataBean> data,Context context){
    // this.data = data;
    // this.data = data;
    //
    //
    // }


    public MyAdapter(List<Bean.DataBean> data, Context context) {
        this.data = data;
        this.context = context;
    }

    @Override
    public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {

        View itemView = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_recycler, parent, false);
        final MyViewHolder myViewHolder = new MyViewHolder(itemView);
        return myViewHolder;

    }

    @Override
    public void onBindViewHolder(final MyViewHolder holder, final int position) {
        holder.itemContentTv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if (onItemClickListener != null) {
                    onItemClickListener.onItemClick(v, position);
                }
            }
        });

        holder.itemContentTv.setText(data.get(position).getName());
        String[] split = data.get(position).getIcon().split("\\|");
        Uri parse = Uri.parse(split[0]);
        holder.simpleDraweeView.setImageURI(parse);
    }

    @Override
    public int getItemCount() {

        return data.size();

    }

    public class MyViewHolder extends RecyclerView.ViewHolder {

        //viewHolder内部有一个itemView成员变量代表的就是整个item布局

        private final TextView itemContentTv;
        private SimpleDraweeView simpleDraweeView;
        public MyViewHolder(final View itemView) {
            super(itemView);
            itemContentTv = itemView.findViewById(R.id.tv_item_content);
         simpleDraweeView=itemView.findViewById(R.id.main_image);
        }
    }


    //给RecyclerView设置条目点击监听
    private OnItemClickListener onItemClickListener;



    public interface OnItemClickListener {

        void onItemClick(View view, int position);

    }
}





public class app extends Application {
    @Override
    public void onCreate() {
        super.onCreate();
        Fresco.initialize(this);
    }
}

Bean

 

public interface MainApi {
    @GET("product/getCatagory")
    Observable<Bean>login();
}

 

package com.ali.recyclerviewdemo;


public class RetrofitManager {
    private static String BASE_URL ="https://www.zhaoapi.cn/";
    private Retrofit mRetrofit;
    private static class SingleHolder {
        private static final RetrofitManager _INSTANT = new RetrofitManager(BASE_URL);
    }
    public static RetrofitManager getDefault() {
        return SingleHolder._INSTANT;
    }
    private RetrofitManager(String baseUrl) {
        mRetrofit = new Retrofit.Builder()
                .baseUrl(baseUrl)
                .addConverterFactory(GsonConverterFactory.create())
                .client(buildOkhttpClinet())
                .addCallAdapterFactory(RxJava2CallAdapterFactory.create())
                .build();
    }
    private OkHttpClient buildOkhttpClinet() {
        return new OkHttpClient.Builder()
                .readTimeout(5, TimeUnit.SECONDS)
                .build();
    }

    public <T> T create(Class<T> Clazz) {
        return mRetrofit.create(Clazz);
    }
}

 

 

 

 

 

 

 

 

 

 

 

 

 

 

内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是一种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进一步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备一定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进一步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值