diff --git a/common/src/main/java/com/yunbao/common/bean/UserAvatarSelectBean.java b/common/src/main/java/com/yunbao/common/bean/UserAvatarSelectBean.java
new file mode 100644
index 000000000..d4efcaca6
--- /dev/null
+++ b/common/src/main/java/com/yunbao/common/bean/UserAvatarSelectBean.java
@@ -0,0 +1,40 @@
+package com.yunbao.common.bean;
+
+public class UserAvatarSelectBean {
+ private int id;
+ private String url;
+ private int select;
+
+ public UserAvatarSelectBean(int id, String url, int select) {
+ this.id = id;
+ this.url = url;
+ this.select = select;
+ }
+
+ public UserAvatarSelectBean() {
+ }
+
+ public int getId() {
+ return id;
+ }
+
+ public void setId(int id) {
+ this.id = id;
+ }
+
+ public String getUrl() {
+ return url;
+ }
+
+ public void setUrl(String url) {
+ this.url = url;
+ }
+
+ public int getSelect() {
+ return select;
+ }
+
+ public void setSelect(int select) {
+ this.select = select;
+ }
+}
diff --git a/common/src/main/java/com/yunbao/common/utils/RouteUtil.java b/common/src/main/java/com/yunbao/common/utils/RouteUtil.java
index aaae75cc4..6ac480e8c 100644
--- a/common/src/main/java/com/yunbao/common/utils/RouteUtil.java
+++ b/common/src/main/java/com/yunbao/common/utils/RouteUtil.java
@@ -43,6 +43,7 @@ public class RouteUtil {
public static final String PATH_RED_PACKET_LIST = "/main/RedPacketListActivity";
public static final String PATH_RED_PACKET_INFO = "/main/RedPacketInfoActivity";
public static final String PATH_RED_PACKET_USER = "/main/RedPacketUsersActivity";
+ public static final String PATH_SELECT_AVATAR="/main/UserAvatarSelectActivity";
public static void forwardFansActivity(String uid) {
ARouter.getInstance().build(PATH_FANSACTIVITY)
@@ -294,4 +295,12 @@ public class RouteUtil {
.withInt("id", id)
.navigation();
}
+
+ /**
+ * 系统头像选择
+ */
+ public static void forwardUserAvatarSelect(){
+ ARouter.getInstance().build(PATH_SELECT_AVATAR)
+ .navigation();
+ }
}
diff --git a/main/src/main/AndroidManifest.xml b/main/src/main/AndroidManifest.xml
index fef1e28bc..40f7204ba 100644
--- a/main/src/main/AndroidManifest.xml
+++ b/main/src/main/AndroidManifest.xml
@@ -156,6 +156,8 @@
+
\ No newline at end of file
diff --git a/main/src/main/java/com/yunbao/main/activity/UserAvatarSelectActivity.java b/main/src/main/java/com/yunbao/main/activity/UserAvatarSelectActivity.java
new file mode 100644
index 000000000..08f4ebda3
--- /dev/null
+++ b/main/src/main/java/com/yunbao/main/activity/UserAvatarSelectActivity.java
@@ -0,0 +1,53 @@
+package com.yunbao.main.activity;
+
+import android.widget.TextView;
+
+import androidx.recyclerview.widget.GridLayoutManager;
+import androidx.recyclerview.widget.RecyclerView;
+
+import com.alibaba.android.arouter.facade.annotation.Route;
+import com.yunbao.common.activity.AbsActivity;
+import com.yunbao.common.bean.UserAvatarSelectBean;
+import com.yunbao.common.utils.RouteUtil;
+import com.yunbao.main.R;
+import com.yunbao.main.adapter.UserAvatarSelectAdapter;
+
+import java.util.ArrayList;
+import java.util.List;
+
+@Route(path = RouteUtil.PATH_SELECT_AVATAR)
+public class UserAvatarSelectActivity extends AbsActivity {
+ RecyclerView recyclerView;
+ UserAvatarSelectAdapter adapter;
+ List list;
+ TextView titleView;
+
+ @Override
+ protected int getLayoutId() {
+ return R.layout.activity_user_select_avatar;
+ }
+
+ @Override
+ protected void main() {
+ super.main();
+ titleView=findViewById(R.id.titleView);
+ titleView.setText("選擇頭像");
+ recyclerView = findViewById(R.id.recyclerView);
+ adapter = new UserAvatarSelectAdapter(mContext);
+ recyclerView.setLayoutManager(new GridLayoutManager(mContext, 3));
+ recyclerView.setAdapter(adapter);
+ test();
+ }
+
+ private void test() {
+ list = new ArrayList<>();
+ for (int i = 0; i < 6; i++) {
+ UserAvatarSelectBean bean = new UserAvatarSelectBean(i,
+ "https://downs.yaoulive.com/20220906170849_79c553dc1319fb5c215e06e01674eba4?imageView2/2/w/600/h/600",
+ i == 3 ? 1 : 0
+ );
+ list.add(bean);
+ }
+ adapter.setList(list);
+ }
+}
diff --git a/main/src/main/java/com/yunbao/main/adapter/UserAvatarSelectAdapter.java b/main/src/main/java/com/yunbao/main/adapter/UserAvatarSelectAdapter.java
new file mode 100644
index 000000000..12cf85782
--- /dev/null
+++ b/main/src/main/java/com/yunbao/main/adapter/UserAvatarSelectAdapter.java
@@ -0,0 +1,77 @@
+package com.yunbao.main.adapter;
+
+import android.content.Context;
+import android.view.LayoutInflater;
+import android.view.View;
+import android.view.ViewGroup;
+
+import androidx.annotation.NonNull;
+import androidx.recyclerview.widget.RecyclerView;
+
+import com.yunbao.common.bean.UserAvatarSelectBean;
+import com.yunbao.common.custom.RatioRoundImageView;
+import com.yunbao.common.glide.ImgLoader;
+import com.yunbao.main.R;
+
+import java.util.List;
+
+public class UserAvatarSelectAdapter extends RecyclerView.Adapter {
+ private Context mContext;
+ private List list;
+ private int select = 0;
+
+ public void setList(List list) {
+ this.list = list;
+ notifyDataSetChanged();
+ }
+
+ public UserAvatarSelectAdapter(Context mContext) {
+ this.mContext = mContext;
+ }
+
+ @NonNull
+ @Override
+ public AvatarSelectViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
+ return new AvatarSelectViewHolder(LayoutInflater.from(mContext).inflate(R.layout.item_user_avatar_select, parent, false));
+ }
+
+ @Override
+ public void onBindViewHolder(@NonNull AvatarSelectViewHolder holder, int position) {
+ holder.setData(list.get(position), position);
+ }
+
+ @Override
+ public int getItemCount() {
+ return list.size();
+ }
+
+ public class AvatarSelectViewHolder extends RecyclerView.ViewHolder {
+ private View hide;
+ private View show;
+ private RatioRoundImageView avatar;
+
+ public AvatarSelectViewHolder(@NonNull View itemView) {
+ super(itemView);
+ hide = itemView.findViewById(R.id.hideCover);
+ show = itemView.findViewById(R.id.showCover);
+ avatar = itemView.findViewById(R.id.avatar);
+ itemView.setOnClickListener(v -> {
+ select = (int) v.getTag();
+ notifyDataSetChanged();
+ });
+ }
+
+ public void setData(UserAvatarSelectBean bean, int position) {
+ ImgLoader.display(itemView.getContext(), bean.getUrl(), avatar);
+ if (select == position) {
+ show.setVisibility(View.VISIBLE);
+ hide.setVisibility(View.GONE);
+ } else {
+ show.setVisibility(View.INVISIBLE);
+ hide.setVisibility(View.VISIBLE);
+ }
+ itemView.setTag(position);
+ }
+ }
+
+}
diff --git a/main/src/main/java/com/yunbao/main/views/MainHomeViewHolder.java b/main/src/main/java/com/yunbao/main/views/MainHomeViewHolder.java
index f04befa48..007d6649b 100644
--- a/main/src/main/java/com/yunbao/main/views/MainHomeViewHolder.java
+++ b/main/src/main/java/com/yunbao/main/views/MainHomeViewHolder.java
@@ -8,6 +8,7 @@ import android.widget.FrameLayout;
import android.widget.ImageView;
import com.yunbao.common.glide.ImgLoader;
+import com.yunbao.common.utils.RouteUtil;
import com.yunbao.main.R;
import com.yunbao.main.activity.RedPacketListActivity;
@@ -41,7 +42,13 @@ public class MainHomeViewHolder extends AbsMainHomeParentViewHolder {
ImgLoader.display(mContext, "https://downs.yaoulive.com/gif_trophy.gif", img_trophy);
-
+ img_trophy.setOnLongClickListener(new View.OnLongClickListener() {
+ @Override
+ public boolean onLongClick(View v) {
+ RouteUtil.forwardUserAvatarSelect();
+ return false;
+ }
+ });
}
public void setCurPosition(int position){
diff --git a/main/src/main/res/drawable/bg_user_avatar_select_selected.xml b/main/src/main/res/drawable/bg_user_avatar_select_selected.xml
new file mode 100644
index 000000000..0a8069452
--- /dev/null
+++ b/main/src/main/res/drawable/bg_user_avatar_select_selected.xml
@@ -0,0 +1,5 @@
+
+
+
+
\ No newline at end of file
diff --git a/main/src/main/res/drawable/bg_user_avatar_select_unselected.xml b/main/src/main/res/drawable/bg_user_avatar_select_unselected.xml
new file mode 100644
index 000000000..85743b326
--- /dev/null
+++ b/main/src/main/res/drawable/bg_user_avatar_select_unselected.xml
@@ -0,0 +1,5 @@
+
+
+
+
\ No newline at end of file
diff --git a/main/src/main/res/layout/activity_user_select_avatar.xml b/main/src/main/res/layout/activity_user_select_avatar.xml
new file mode 100644
index 000000000..52c939dc4
--- /dev/null
+++ b/main/src/main/res/layout/activity_user_select_avatar.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/main/src/main/res/layout/item_user_avatar_select.xml b/main/src/main/res/layout/item_user_avatar_select.xml
new file mode 100644
index 000000000..38550d8e2
--- /dev/null
+++ b/main/src/main/res/layout/item_user_avatar_select.xml
@@ -0,0 +1,52 @@
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file