From fe2d0d8bde0f4e5d05e2c2c71eca75cec236313d Mon Sep 17 00:00:00 2001 From: linlhp <429586155@qq.com> Date: Wed, 29 May 2019 23:28:30 +0800 Subject: [PATCH] First Commit of Finish Job --- app/build.gradle | 2 +- app/src/main/AndroidManifest.xml | 1 + .../frt/recentconversation/MainActivity.java | 43 ++++++++++ .../activity/DetailActivity.java | 74 ++++++++++++++++++ .../adapter/UserAdapter.java | 29 +++++-- .../recentconversation/model/UserInfo.java | 4 +- .../res/drawable-anydpi/ic_action_add.xml | 10 +++ .../main/res/drawable-hdpi/ic_action_add.png | Bin 0 -> 144 bytes .../main/res/drawable-mdpi/ic_action_add.png | Bin 0 -> 97 bytes .../main/res/drawable-xhdpi/ic_action_add.png | Bin 0 -> 120 bytes .../res/drawable-xxhdpi/ic_action_add.png | Bin 0 -> 156 bytes app/src/main/res/layout/activity_detail.xml | 34 ++++++++ app/src/main/res/menu/menu_main.xml | 12 +++ app/src/main/res/values/strings.xml | 3 + 14 files changed, 203 insertions(+), 9 deletions(-) create mode 100644 app/src/main/java/com/nd/frt/recentconversation/activity/DetailActivity.java create mode 100644 app/src/main/res/drawable-anydpi/ic_action_add.xml create mode 100644 app/src/main/res/drawable-hdpi/ic_action_add.png create mode 100644 app/src/main/res/drawable-mdpi/ic_action_add.png create mode 100644 app/src/main/res/drawable-xhdpi/ic_action_add.png create mode 100644 app/src/main/res/drawable-xxhdpi/ic_action_add.png create mode 100644 app/src/main/res/layout/activity_detail.xml create mode 100644 app/src/main/res/menu/menu_main.xml diff --git a/app/build.gradle b/app/build.gradle index f6cd147..831b56e 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -25,7 +25,7 @@ dependencies { implementation 'com.google.code.gson:gson:2.8.5' implementation 'com.github.bumptech.glide:glide:4.5.0' annotationProcessor 'com.github.bumptech.glide:compiler:4.5.0' - implementation 'com.android.support:recyclerview-v7:28.0.0' + implementation 'com.android.support:recyclerview-v7:28.0.0' testImplementation 'junit:junit:4.12' androidTestImplementation 'com.android.support.test:runner:1.0.2' androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2' diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index dee705b..15286cc 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -11,6 +11,7 @@ android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:theme="@style/AppTheme"> + diff --git a/app/src/main/java/com/nd/frt/recentconversation/MainActivity.java b/app/src/main/java/com/nd/frt/recentconversation/MainActivity.java index 92c3b81..bff6ca5 100644 --- a/app/src/main/java/com/nd/frt/recentconversation/MainActivity.java +++ b/app/src/main/java/com/nd/frt/recentconversation/MainActivity.java @@ -1,18 +1,27 @@ package com.nd.frt.recentconversation; +import android.content.Intent; import android.os.Bundle; +import android.support.annotation.Nullable; import android.support.v7.app.AppCompatActivity; import android.support.v7.widget.LinearLayoutManager; import android.support.v7.widget.RecyclerView; +import android.view.Menu; +import android.view.MenuItem; +import com.nd.frt.recentconversation.activity.DetailActivity; import com.nd.frt.recentconversation.adapter.UserAdapter; import com.nd.frt.recentconversation.model.UserInfo; import com.nd.frt.recentconversation.service.UserInfoService; import java.util.List; +import static com.nd.frt.recentconversation.activity.DetailActivity.PARAM_USER_INDEX; + public class MainActivity extends AppCompatActivity { + private UserAdapter mUserAdapter; + @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); @@ -22,7 +31,41 @@ protected void onCreate(Bundle savedInstanceState) { UserAdapter userAdapter = new UserAdapter(userInfos); RecyclerView recyclerView = (RecyclerView) findViewById(R.id.rvRecyclerView); recyclerView.setLayoutManager(new LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false)); + mUserAdapter = new UserAdapter(userInfos); recyclerView.setAdapter(userAdapter); } + @Override + public boolean onCreateOptionsMenu(Menu menu) { + getMenuInflater().inflate(R.menu.menu_main,menu); + return true; + } + + @Override + public boolean onOptionsItemSelected(MenuItem item) { + if (item.getItemId() == R.id.menu_add){ + UserInfo userInfo = new UserInfo(); + userInfo.userName = "linlhp"; + userInfo.content = "429586155@qq.com"; + userInfo.avatarUrl = "https://randomuser.me/api/portraits/med/women/64.jpg"; + mUserAdapter.add(userInfo); + return true; + + } + return super.onOptionsItemSelected(item); + } + + + @Override + protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) { + super.onActivityResult(requestCode, resultCode, data); + if (resultCode == RESULT_OK){ + if (data != null) { + UserInfo userInfo = ((UserInfo) data.getSerializableExtra(DetailActivity.PARAM_USER_INFO)); + int index = data.getIntExtra(DetailActivity.PARAM_USER_INDEX,0); + mUserAdapter.edit(index,userInfo); + } + } + + } } diff --git a/app/src/main/java/com/nd/frt/recentconversation/activity/DetailActivity.java b/app/src/main/java/com/nd/frt/recentconversation/activity/DetailActivity.java new file mode 100644 index 0000000..e7b90f5 --- /dev/null +++ b/app/src/main/java/com/nd/frt/recentconversation/activity/DetailActivity.java @@ -0,0 +1,74 @@ +package com.nd.frt.recentconversation.activity; + +import android.app.Activity; +import android.content.Context; +import android.content.Intent; +import android.support.v7.app.ActionBar; +import android.support.v7.app.AppCompatActivity; +import android.os.Bundle; +import android.view.MenuItem; +import android.view.View; +import android.widget.EditText; +import android.widget.ImageView; + +import com.bumptech.glide.Glide; +import com.nd.frt.recentconversation.R; +import com.nd.frt.recentconversation.model.UserInfo; + +import java.time.Instant; + +public class DetailActivity extends AppCompatActivity { + + public static final String PARAM_USER_INFO ="user_info" ; + public static final String PARAM_USER_INDEX = "user_index"; + private UserInfo mUserInfo; + private int mUserIndex; + + public static void start(Activity context, int index, UserInfo userInfo,int requestCode) { + Intent starter = new Intent(context, DetailActivity.class); + starter.putExtra(PARAM_USER_INFO,userInfo); + starter.putExtra(PARAM_USER_INDEX,index); + context.startActivityForResult(starter,requestCode); + } + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_detail); + ActionBar supportActionBar = getSupportActionBar(); + assert supportActionBar != null; + supportActionBar.setDisplayHomeAsUpEnabled(true); + Intent intent = getIntent(); + mUserInfo = ((UserInfo) intent.getSerializableExtra(PARAM_USER_INFO)); + mUserIndex = intent.getIntExtra(PARAM_USER_INDEX,0); + supportActionBar.setTitle(mUserInfo.userName); + supportActionBar.setSubtitle(mUserInfo.content); + final EditText etUserName = findViewById(R.id.etUserName); + ImageView ivAvatar = findViewById(R.id.ivAvatar); + Glide.with(this) + .load(mUserInfo.avatarUrl) + .into(ivAvatar); + findViewById(R.id.btnok).setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + mUserInfo.userName = etUserName.getText().toString(); + Intent intentResult = new Intent(); + intentResult.putExtra(PARAM_USER_INFO,mUserInfo); + intentResult.putExtra(PARAM_USER_INDEX,mUserIndex); + setResult(RESULT_OK,intentResult); + finish(); + + } + }); + } + + + @Override + public boolean onOptionsItemSelected(MenuItem item) { + if (item.getItemId() == android.R.id.home){ + finish(); + return true; + } + return super.onOptionsItemSelected(item); + } +} diff --git a/app/src/main/java/com/nd/frt/recentconversation/adapter/UserAdapter.java b/app/src/main/java/com/nd/frt/recentconversation/adapter/UserAdapter.java index f644c4e..778169f 100644 --- a/app/src/main/java/com/nd/frt/recentconversation/adapter/UserAdapter.java +++ b/app/src/main/java/com/nd/frt/recentconversation/adapter/UserAdapter.java @@ -1,5 +1,7 @@ package com.nd.frt.recentconversation.adapter; +import android.app.Activity; +import android.app.DownloadManager; import android.support.annotation.NonNull; import android.support.v7.widget.RecyclerView; import android.util.Log; @@ -10,6 +12,7 @@ import com.bumptech.glide.Glide; import com.nd.frt.recentconversation.R; +import com.nd.frt.recentconversation.activity.DetailActivity; import com.nd.frt.recentconversation.model.UserInfo; import com.nd.frt.recentconversation.viewholder.UserViewHolder; @@ -17,34 +20,37 @@ public class UserAdapter extends RecyclerView.Adapter { - public static final String TAG = UserAdapter.class.getSimpleName(); + private static final int REQUEST_EDIT_USER_INFO = 0*1001; private List mUserInfos; public UserAdapter(List userInfos) { mUserInfos = userInfos; } + @NonNull @Override public UserViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int i) { LayoutInflater layoutInflater = LayoutInflater.from(viewGroup.getContext()); View inflate = layoutInflater.inflate(R.layout.item_user, viewGroup, false); - Log.d(TAG, "onCreateViewHolder"); + return new UserViewHolder(inflate); } @Override - public void onBindViewHolder(@NonNull UserViewHolder userViewHolder, int position) { - Log.d(TAG, "onBindViewHolder"); + public void onBindViewHolder(@NonNull UserViewHolder userViewHolder, final int position) { + final UserInfo userInfo = mUserInfos.get(position); - Glide.with(userViewHolder.mIvAvatar).load(userInfo.avatarUrl).into(userViewHolder.mIvAvatar); + Glide.with(userViewHolder.mIvAvatar). + load(userInfo.avatarUrl). + into(userViewHolder.mIvAvatar); userViewHolder.mTvUserName.setText(userInfo.userName); userViewHolder.mTvEmail.setText(userInfo.content); - userViewHolder.mIvAvatar.setOnClickListener(new View.OnClickListener() { + userViewHolder.itemView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { - Toast.makeText(v.getContext(), v.getContext().getString(R.string.hello), Toast.LENGTH_LONG).show(); + DetailActivity.start((Activity) v.getContext(), position ,userInfo, REQUEST_EDIT_USER_INFO); } }); } @@ -53,4 +59,13 @@ public void onClick(View v) { public int getItemCount() { return mUserInfos.size(); } + + public void add(UserInfo userInfo){ + mUserInfos.add(userInfo); + notifyDataSetChanged(); + } + public void edit(int index,UserInfo userInfo){ + mUserInfos.set(index,userInfo); + notifyDataSetChanged(); + } } diff --git a/app/src/main/java/com/nd/frt/recentconversation/model/UserInfo.java b/app/src/main/java/com/nd/frt/recentconversation/model/UserInfo.java index e70191b..d7612af 100644 --- a/app/src/main/java/com/nd/frt/recentconversation/model/UserInfo.java +++ b/app/src/main/java/com/nd/frt/recentconversation/model/UserInfo.java @@ -1,6 +1,8 @@ package com.nd.frt.recentconversation.model; -public class UserInfo { +import java.io.Serializable; + +public class UserInfo implements Serializable { public String avatarUrl; public String userName; diff --git a/app/src/main/res/drawable-anydpi/ic_action_add.xml b/app/src/main/res/drawable-anydpi/ic_action_add.xml new file mode 100644 index 0000000..89208a9 --- /dev/null +++ b/app/src/main/res/drawable-anydpi/ic_action_add.xml @@ -0,0 +1,10 @@ + + + diff --git a/app/src/main/res/drawable-hdpi/ic_action_add.png b/app/src/main/res/drawable-hdpi/ic_action_add.png new file mode 100644 index 0000000000000000000000000000000000000000..d702a21d2cdbcdf13a6cdda9318fe432317a00ac GIT binary patch literal 144 zcmeAS@N?(olHy`uVBq!ia0vp^Dj>|k1|%Oc%$NbB!aZFaLn>~)z2?ZpARyon=stV) z*^4r{0aJPxt&sd1zj8(! literal 0 HcmV?d00001 diff --git a/app/src/main/res/layout/activity_detail.xml b/app/src/main/res/layout/activity_detail.xml new file mode 100644 index 0000000..edd153d --- /dev/null +++ b/app/src/main/res/layout/activity_detail.xml @@ -0,0 +1,34 @@ + + + + + + + +