Android制作微信添加多个图片,放大图片

news/2024/11/15 4:08:17/

1.添加依赖

implementation 'com.github.bumptech.glide:glide:4.12.0' //裁剪图片等等
implementation 'androidx.recyclerview:recyclerview:1.1.0' //recycleview依赖

2.使用recycleview

    <androidx.recyclerview.widget.RecyclerViewandroid:id="@+id/recyclerView"android:layout_width="match_parent"android:layout_height="wrap_content" />

3.编写两个item页面为recycleview的子页面

<?xml version="1.0" encoding="utf-8"?>
<Button xmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/btnAdd"android:layout_width="100dp"android:layout_height="120dp"android:layout_margin="4dp"android:layout_weight="1"android:text="Add"/>
//点击添加按钮
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="wrap_content"android:layout_height="wrap_content"android:orientation="horizontal"android:padding="8dp"><ImageViewandroid:id="@+id/imgView"android:layout_width="100dp"android:layout_height="100dp"/></LinearLayout>

4.写recycleview的适配器

package com.example.myapplication;import android.content.Context;
import android.content.Intent;
import android.net.Uri;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.ImageView;import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;import com.bumptech.glide.Glide;import java.util.ArrayList;public class ImageAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> {private final int VIEW_TYPE_IMAGE = 0;private final int VIEW_TYPE_ADD_BUTTON = 1;private ArrayList<Uri> imageUris;private Context context;private LayoutInflater inflater;private OnAddButtonClickListener addButtonClickListener;public interface OnAddButtonClickListener {void onAddButtonClick();}public ImageAdapter(Context context, OnAddButtonClickListener listener) {this.context = context;this.imageUris = new ArrayList<>();this.inflater = LayoutInflater.from(context);this.addButtonClickListener = listener;}public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {if (viewType == VIEW_TYPE_IMAGE) {View itemView = inflater.inflate(R.layout.iteam, parent, false);return new ImageViewHolder(itemView);} else {View itemView = inflater.inflate(R.layout.iteambutton, parent, false);Button addButton = itemView.findViewById(R.id.btnAdd);addButton.setOnClickListener(v -> addButtonClickListener.onAddButtonClick());return new AddButtonViewHolder(itemView);}}@Overridepublic void onBindViewHolder(@NonNull RecyclerView.ViewHolder holder, int position) {if (getItemViewType(position) == VIEW_TYPE_IMAGE) {Uri uri = imageUris.get(position);ImageViewHolder imageHolder = (ImageViewHolder) holder;Glide.with(context).load(uri).centerCrop().into( imageHolder.imageView);//点击图片 放大图片,跳转页面imageHolder.imageView.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {Intent intent=new Intent(context,emptyActivity.class);intent.putExtra("url",uri.toString());context.startActivity(intent);}});}}@Overridepublic int getItemCount() {// Plus one for the add buttonreturn imageUris.size() + 1}@Overridepublic int getItemViewType(int position) {return position == imageUris.size() ? VIEW_TYPE_ADD_BUTTON : VIEW_TYPE_IMAGE;}public void addImage(Uri uri) {imageUris.add(uri);notifyItemInserted(imageUris.size() - 1);}static class ImageViewHolder extends RecyclerView.ViewHolder {ImageView imageView;ImageViewHolder(View itemView) {super(itemView);imageView = itemView.findViewById(R.id.imgView);}}static class AddButtonViewHolder extends RecyclerView.ViewHolder {AddButtonViewHolder(View itemView) {super(itemView);}}
}

5.编写java文件

package com.example.myapplication;import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.provider.MediaStore;import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.GridLayoutManager;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;import java.util.ArrayList;public class RecyCleActivity extends AppCompatActivity  implements ImageAdapter.OnAddButtonClickListener{private static final int REQUEST_CODE_PICK_IMAGE = 1;private ImageAdapter imageAdapter;private RecyclerView recyclerView;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_recy_cle);recyclerView = findViewById(R.id.recyclerView);recyclerView.setLayoutManager(new GridLayoutManager(this,3));imageAdapter = new ImageAdapter(this, this);recyclerView.setAdapter(imageAdapter);}@Overridepublic void onAddButtonClick() {Intent intent = new Intent(Intent.ACTION_PICK, MediaStore.Images.Media.EXTERNAL_CONTENT_URI);startActivityForResult(intent, REQUEST_CODE_PICK_IMAGE);}protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {super.onActivityResult(requestCode, resultCode, data);if (requestCode == REQUEST_CODE_PICK_IMAGE && resultCode == RESULT_OK) {if (data != null) {Uri selectedImageUri = data.getData();if (selectedImageUri != null) {imageAdapter.addImage(selectedImageUri);}}}}
}

6.编写点击图片后放大图片,创建emptyActivity页面

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><ImageViewandroid:id="@+id/img"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerHorizontal="true"android:layout_centerVertical="true"/></RelativeLayout>
package com.example.myapplication;import androidx.appcompat.app.AppCompatActivity;import android.net.Uri;
import android.os.Bundle;
import android.widget.ImageView;import com.bumptech.glide.Glide;import javax.microedition.khronos.opengles.GL;public class emptyActivity extends AppCompatActivity {private ImageView img;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_empty);img=findViewById(R.id.img);String imageUriString = getIntent().getStringExtra("url");Glide.with(emptyActivity.this).load(imageUriString).into(img);}
}


http://www.ppmy.cn/news/1387179.html

相关文章

【电路笔记】-MOSFET作为开关

MOSFET 作为开关 文章目录 MOSFET 作为开关1、概述2、MOSFET特性曲线2.1 截住区域2.2 饱和区域3、MOSFET作为开关的示例4、功率MOSFET电机控制5、P沟道MOSFET作为开关6、互补MOSFET作为开关电机控制器当 MOSFET 在截止区和饱和区之间工作时,MOSFET 是非常好的电子开关,用于控…

LeetCode——贪心算法(Java)

贪心算法 简介[简单] 455. 分发饼干[中等] 376. 摆动序列[中等] 53. 最大子数组和[中等] 122. 买卖股票的最佳时机 II[中等] 55. 跳跃游戏 简介 记录一下自己刷题的历程以及代码。写题过程中参考了 代码随想录的刷题路线。会附上一些个人的思路&#xff0c;如果有错误&#xf…

MQ组件之RabbitMQ学习

MQ组件之RabbitMQ入门 同步调用和异步调用 在微服务架构中&#xff0c;服务之间的调用有同步调用和异步调用两种方式。 我们使用OpenFeign去调用是同步调用&#xff0c;同步调用的缺点很明显&#xff0c;在下图的场景中&#xff0c;支付完成后需要调用订单服务、仓库服务、短…

吴恩达深度学习环境本地化构建wsl+docker+tensorflow+cuda

Tensorflow2 on wsl using cuda 动机环境选择安装步骤1. WSL安装2. docker安装2.1 配置Docker Desktop2.2 WSL上的docker使用2.3 Docker Destop的登陆2.4 测试一下 3. 在WSL上安装CUDA3.1 Software list needed3.2 [CUDA Support for WSL 2](https://docs.nvidia.com/cuda/wsl-…

数据结构与算法Bonus-KNN问题的代码求解过程

一、问题提出 &#xff08;一&#xff09;要求 1.随机生成>10万个三维点的点云&#xff0c;并以适当方式存储 2.自行实现一个KNN算法&#xff0c;对任意Query点&#xff0c;返回最邻近的K个点 3.不允许使用第三方库(e.g.flann&#xff0c;PCL,opencv)! 4.语言任选(推荐…

本地虚拟机平台Proxmox VE结合Cpolar内网穿透实现公网远程访问

&#x1f525;博客主页&#xff1a; 小羊失眠啦. &#x1f3a5;系列专栏&#xff1a;《C语言》 《数据结构》 《C》 《Linux》 《Cpolar》 ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&…

pmp培训选择线上还是线下呢?

准备考PMP&#xff0c;到底是选择线上培训还是传统的线下面授课程更划算呢&#xff1f; 这个决定受到许多因素的影响&#xff0c;比如你的时间安排、学习习惯和预算。 接下来我将详细比较这两种方式&#xff0c;帮助你做出更适合自己的选择。 1、 网络直播课 网络直播课是指…

羊大师揭秘,如何判断孩子抵抗力

羊大师揭秘&#xff0c;如何判断孩子抵抗力 判断孩子的免疫力强不强&#xff0c;可以从以下几个方面综合考虑&#xff1a; 观察孩子的饮食和排便情况&#xff1a;如果孩子饮食正常&#xff0c;排便顺畅&#xff0c;没有出现恶心、呕吐、腹胀、腹泻等消化功能异常的表现&#…