加载更多修改

dev
李桢 2 years ago
parent 2f91bae03c
commit c7bea3071c
  1. 92
      app/src/main/java/com/unionmed/unionmedtv/activity/DoctorActivity.java
  2. 2
      app/src/main/java/com/unionmed/unionmedtv/activity/HospitalActivity.java

@ -41,15 +41,17 @@ public class DoctorActivity extends BaseActivity {
private DoctorAdapter doctorAdapter; private DoctorAdapter doctorAdapter;
private int startNum = 0; private int startNum = 0;
private int endNum = 10; private int endNum = 10;
private int numberOfColumns=4; private int numberOfColumns = 4;
private int selectPostion = 0;//当前列表item点击位置 private int selectPostion = 0;//当前列表item点击位置
private EditText et_search; private EditText et_search;
private Handler handler = new Handler(); private Handler handler = new Handler();
List<GetNearDoctorApi.DoctorInfo.MemberBean> list=new ArrayList<>(); List<GetNearDoctorApi.DoctorInfo.MemberBean> list = new ArrayList<>();
public static void StartActivity(Context context){
Intent intent=new Intent(context, DoctorActivity.class); public static void StartActivity(Context context) {
Intent intent = new Intent(context, DoctorActivity.class);
context.startActivity(intent); context.startActivity(intent);
} }
@Override @Override
protected void onCreate(@Nullable Bundle savedInstanceState) { protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
@ -60,12 +62,12 @@ public class DoctorActivity extends BaseActivity {
} }
public void initView(){ public void initView() {
et_search=findViewById(R.id.et_search); et_search = findViewById(R.id.et_search);
et_search.setOnFocusChangeListener(new View.OnFocusChangeListener() { et_search.setOnFocusChangeListener(new View.OnFocusChangeListener() {
@Override @Override
public void onFocusChange(View view, boolean b) { public void onFocusChange(View view, boolean b) {
InputKeyBoardUtils.show(DoctorActivity.this,view,b); InputKeyBoardUtils.show(DoctorActivity.this, view, b);
} }
}); });
et_search.addTextChangedListener(new TextWatcher() { et_search.addTextChangedListener(new TextWatcher() {
@ -85,27 +87,28 @@ public class DoctorActivity extends BaseActivity {
} }
}); });
recyclerView=findViewById(R.id.recyclerView); recyclerView = findViewById(R.id.recyclerView);
recyclerView.requestFocus(); recyclerView.requestFocus();
MyGridLayoutManager gridLayoutManager= new MyGridLayoutManager(DoctorActivity.this,numberOfColumns); MyGridLayoutManager gridLayoutManager = new MyGridLayoutManager(DoctorActivity.this, numberOfColumns);
gridLayoutManager.setUpView(et_search); gridLayoutManager.setUpView(et_search);
recyclerView.setLayoutManager(gridLayoutManager); recyclerView.setLayoutManager(gridLayoutManager);
doctorAdapter =new DoctorAdapter(R.layout.item_type_doctor_layout,list, new OnChildClickListener() { doctorAdapter = new DoctorAdapter(R.layout.item_type_doctor_layout, list, new OnChildClickListener() {
@Override @Override
public <T> void onChildClick(View view, int position, T data) { public <T> void onChildClick(View view, int position, T data) {
selectPostion = position; selectPostion = position;
GetNearDoctorApi.DoctorInfo.MemberBean memberBean= (GetNearDoctorApi.DoctorInfo.MemberBean) data; GetNearDoctorApi.DoctorInfo.MemberBean memberBean = (GetNearDoctorApi.DoctorInfo.MemberBean) data;
if (memberBean.isLast()) { if (memberBean.isLast()) {
startNum = startNum + endNum; startNum = startNum + endNum;
loadData(0); loadData(0);
} else { } else {
DoctorDetailActivity.StartActivity(DoctorActivity.this,memberBean.getPersoninfo().get(0).getUseraccount()); DoctorDetailActivity.StartActivity(DoctorActivity.this, memberBean.getPersoninfo().get(0).getUseraccount());
} }
} }
}); });
recyclerView.setAdapter(doctorAdapter); recyclerView.setAdapter(doctorAdapter);
recyclerView.addItemDecoration(new LinearSpacingItemDecoration(DoctorActivity.this,14)); recyclerView.addItemDecoration(new LinearSpacingItemDecoration(DoctorActivity.this, 14));
} }
private Runnable searchRunnable = new Runnable() { private Runnable searchRunnable = new Runnable() {
@Override @Override
public void run() { public void run() {
@ -129,41 +132,42 @@ public class DoctorActivity extends BaseActivity {
@Override @Override
public void onSucceed(HttpData<ApiResponse<GetNearDoctorApi.DoctorInfo>> stringHttpData) { public void onSucceed(HttpData<ApiResponse<GetNearDoctorApi.DoctorInfo>> stringHttpData) {
LogUtils.e("成功:" + stringHttpData); LogUtils.e("成功:" + stringHttpData);
if (stringHttpData.getData().getCode() == 200) { if (stringHttpData.isRequestSucceed()) {
List<GetNearDoctorApi.DoctorInfo.MemberBean> doctorInfo = stringHttpData.getData().getData().getMember(); if (stringHttpData.getData().isInnerRequestSucceed()) {
if (doctorInfo == null) { List<GetNearDoctorApi.DoctorInfo.MemberBean> doctorInfo = stringHttpData.getData().getData().getMember();
return; if (doctorInfo == null) {
} return;
if (type == 0) { }
list.remove(list.size() - 1); if (type == 0) {
} list.remove(list.size() - 1);
list.addAll(doctorInfo); }
if (doctorInfo.size() == endNum) { list.addAll(doctorInfo);
GetNearDoctorApi.DoctorInfo.MemberBean memberBean = new GetNearDoctorApi.DoctorInfo.MemberBean(); if (doctorInfo.size() == endNum) {
memberBean.setLast(true); GetNearDoctorApi.DoctorInfo.MemberBean memberBean = new GetNearDoctorApi.DoctorInfo.MemberBean();
list.add(memberBean); memberBean.setLast(true);
} list.add(memberBean);
}
doctorAdapter.notifyDataSetChanged();
if (type == 0) { doctorAdapter.notifyDataSetChanged();
recyclerView.requestFocus(); if (type == 0) {
recyclerView.post(new Runnable() { recyclerView.post(new Runnable() {
@Override @Override
public void run() { public void run() {
if (doctorInfo.size() == 0) { if (doctorInfo.size() == 0) {
selectPostion = selectPostion - 1; selectPostion = selectPostion - 1;
} }
View view = recyclerView.getLayoutManager().findViewByPosition(selectPostion); View view = recyclerView.getLayoutManager().findViewByPosition(selectPostion);
if (view != null) { if (view != null) {
recyclerView.requestFocus(); view.requestFocus();
view.requestFocus(); }
} }
} });
}); }
}
}
} }
} }
@Override @Override

@ -147,7 +147,6 @@ public class HospitalActivity extends BaseActivity {
} }
hospitalAdapter.notifyDataSetChanged(); hospitalAdapter.notifyDataSetChanged();
if (type == 0) { if (type == 0) {
recyclerView.requestFocus();
recyclerView.post(new Runnable() { recyclerView.post(new Runnable() {
@Override @Override
public void run() { public void run() {
@ -156,7 +155,6 @@ public class HospitalActivity extends BaseActivity {
} }
View view = recyclerView.getLayoutManager().findViewByPosition(selectPostion); View view = recyclerView.getLayoutManager().findViewByPosition(selectPostion);
if (view != null) { if (view != null) {
recyclerView.requestFocus();
view.requestFocus(); view.requestFocus();
} }
} }

Loading…
Cancel
Save