点击item/图片二次采样

本文介绍了一个自定义的RecyclerView适配器实现方法,并详细展示了如何使用OkHttp进行图片的网络请求及BitmapUtils类中对图片进行采样和尺寸调整的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

==========================================================Adapter==========================================================

public class MyGridAdapter extends RecyclerView.Adapter<MyGridAdapter.MyViewHolder>{
    Context context;
    ztbean zt;
    OnItemClickListener listener;
    Handler handler=new Handler();
    public MyGridAdapter(Context context, ztbean zt) {
        this.context = context;
        this.zt = zt;
    }
    public  interface  OnItemClickListener{
        void onItemClick(View view,int position);
    }

    public void setOnItemClickListener(OnItemClickListener listener){
        this.listener = listener;
    }

    @Override
    public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view=View.inflate(context, R.layout.grid_item,null);
        MyViewHolder holder=new MyViewHolder(view);
        return holder;
    }

    @Override
    public void onBindViewHolder(final MyViewHolder holder, final int position) {
        holder.tv2.setText(zt.getOthers().get(position).getName());
//        ImageLoader.getInstance().displayImage(zt.getOthers().get(position).getThumbnail(),holder.iv2);
        OkHttpUtils.getInstance().doGet(zt.getOthers().get(position).getThumbnail(), new Callback() {
            @Override
            public void onFailure(Call call, IOException e) {

            }

            @Override
            public void onResponse(Call call, Response response) throws IOException {
                  final Bitmap b= BitmapUtils.getBitmap(response.body().bytes(),100,100);
                   handler.post(new Runnable() {
                       @Override
                       public void run() {
                           holder.iv2.setImageBitmap(b);
                       }
                   });

            }
        });


        holder.iv2.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                int postion=holder.getLayoutPosition();
                listener.onItemClick(holder.itemView,position);
            }
        });
    }

    @Override
    public int getItemCount() {
        return zt.getOthers().size();
    }

    public class MyViewHolder extends RecyclerView.ViewHolder{
        ImageView iv2;
        TextView tv2;
       public MyViewHolder(View itemView) {
           super(itemView);
           tv2=itemView.findViewById(R.id.tv2);
           iv2=itemView.findViewById(R.id.iv2);
       }
   }



}
==========================================================BitMapUtils========================================================

public class BitmapUtils {
    /**
     * @param filePath   要加载的图片路径
     * @param destWidth  显示图片的控件宽度
     * @param destHeight 显示图片的控件的高度
     * @return
     */
    public static android.graphics.Bitmap getBitmap(String filePath, int destWidth, int destHeight) {
        //第一次采样
        BitmapFactory.Options options = new BitmapFactory.Options();
        //该属性设置为true只会加载图片的边框进来,并不会加载图片具体的像素点
        options.inJustDecodeBounds = true;
        //第一次加载图片,这时只会加载图片的边框进来,并不会加载图片中的像素点
        BitmapFactory.decodeFile(filePath, options);
        //获得原图的宽和高
        int outWidth = options.outWidth;
        int outHeight = options.outHeight;
        //定义缩放比例
        int sampleSize = 1;
        while (outHeight / sampleSize > destHeight || outWidth / sampleSize > destWidth) {
            //如果宽高的任意一方的缩放比例没有达到要求,都继续增大缩放比例
            //sampleSize应该为2n次幂,如果给sampleSize设置的数字不是2n次幂,那么系统会就近取值
            sampleSize *= 2;
        }
        /********************************************************************************************/
        //至此,第一次采样已经结束,我们已经成功的计算出了sampleSize的大小
        /********************************************************************************************/
        //二次采样开始
        //二次采样时我需要将图片加载出来显示,不能只加载图片的框架,因此inJustDecodeBounds属性要设置为false
        options.inJustDecodeBounds = false;
        //设置缩放比例
        options.inSampleSize = sampleSize;
        //加载图片并返回
        return BitmapFactory.decodeFile(filePath, options);
    }

    public static android.graphics.Bitmap getBitmap(byte[] filePath, int destWidth, int destHeight) {
        //第一次采样
        BitmapFactory.Options options = new BitmapFactory.Options();
        //该属性设置为true只会加载图片的边框进来,并不会加载图片具体的像素点
        options.inJustDecodeBounds = true;
        //第一次加载图片,这时只会加载图片的边框进来,并不会加载图片中的像素点
        BitmapFactory.decodeByteArray(filePath, 0, filePath.length, options);
        //获得原图的宽和高
        int outWidth = options.outWidth;
        int outHeight = options.outHeight;
        //定义缩放比例
        int sampleSize = 1;
        while (outHeight / sampleSize > destHeight || outWidth / sampleSize > destWidth) {
            //如果宽高的任意一方的缩放比例没有达到要求,都继续增大缩放比例
            //sampleSize应该为2n次幂,如果给sampleSize设置的数字不是2n次幂,那么系统会就近取值
            sampleSize *= 2;
        }
        /********************************************************************************************/
        //至此,第一次采样已经结束,我们已经成功的计算出了sampleSize的大小
        /********************************************************************************************/
        //二次采样开始
        //二次采样时我需要将图片加载出来显示,不能只加载图片的框架,因此inJustDecodeBounds属性要设置为false
        options.inJustDecodeBounds = false;
        //设置缩放比例
        options.inSampleSize = sampleSize;
        //加载图片并返回
        return BitmapFactory.decodeByteArray(filePath, 0, filePath.length, options);
    }
}

内容概要:本文深入解析了扣子COZE AI编程及其详细应用代码案例,旨在帮助读者理解新一代低门槛智能体开发范式。文章从五个维度展开:关键概念、核心技巧、典型应用场景、详细代码案例分析以及未来发展趋势。首先介绍了扣子COZE的核心概念,如Bot、Workflow、Plugin、Memory和Knowledge。接着分享了意图识别、函数调用链、动态Prompt、渐进式发布及监控可观测等核心技巧。然后列举了企业内部智能客服、电商导购助手、教育领域AI助教和金融行业合规质检等应用场景。最后,通过构建“会议纪要智能助手”的详细代码案例,展示了从需求描述、技术方案、Workflow节点拆解到调试与上线的全过程,并展望了多智能体协作、本地私有部署、Agent2Agent协议、边缘计算插件和实时RAG等未来发展方向。; 适合人群:对AI编程感兴趣的开发者,尤其是希望快速落地AI产品的技术人员。; 使用场景及目标:①学习如何使用扣子COZE构建生产级智能体;②掌握智能体实例、自动化流程、扩展能力和知识库的使用方法;③通过实际案例理解如何实现会议纪要智能助手的功能,包括触发器设置、下载节点、LLM节点Prompt设计、Code节点处理和邮件节点配置。; 阅读建议:本文不仅提供了理论知识,还包含了详细的代码案例,建议读者结合实际业务需求进行实践,逐步掌握扣子COZE的各项功能,并关注其未来的发展趋势。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值