Skip to content

Commit

Permalink
new advanced recycler view and adapter impl
Browse files Browse the repository at this point in the history
  • Loading branch information
mcxiaoke committed Jun 17, 2018
1 parent 9bec3f6 commit b6bc2f5
Show file tree
Hide file tree
Showing 12 changed files with 609 additions and 22 deletions.
4 changes: 2 additions & 2 deletions build.gradle
@@ -1,6 +1,6 @@
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
ext.support_version = '27.1.0'
ext.support_version = '27.1.1'

repositories {
jcenter()
Expand All @@ -10,7 +10,7 @@ buildscript {
}

dependencies {
classpath 'com.android.tools.build:gradle:3.1.0'
classpath 'com.android.tools.build:gradle:3.1.3'
}
}

Expand Down
2 changes: 1 addition & 1 deletion core/build.gradle
Expand Up @@ -3,7 +3,7 @@ apply plugin: 'com.android.library'
dependencies {

testImplementation 'junit:junit:4.12'
testImplementation 'org.mockito:mockito-core:1.10.19'
testImplementation 'org.mockito:mockito-core:2.18.3'
}

apply from: '../base.gradle'
Expand Down
4 changes: 2 additions & 2 deletions func/build.gradle
Expand Up @@ -2,9 +2,9 @@ apply plugin: 'com.android.library'

dependencies {
// compile project(":core")
testImplementation 'com.google.guava:guava:18.0'
testImplementation 'com.google.guava:guava:22.0'
testImplementation 'junit:junit:4.12'
testImplementation 'org.mockito:mockito-core:1.10.19'
testImplementation 'org.mockito:mockito-core:2.18.3'
}

apply from: '../base.gradle'
Expand Down
4 changes: 2 additions & 2 deletions http/build.gradle
Expand Up @@ -8,8 +8,8 @@ dependencies {

testImplementation 'com.google.code.gson:gson:2.8.2'
testImplementation 'junit:junit:4.12'
testImplementation 'org.mockito:mockito-core:1.10.19'
androidTestImplementation 'com.android.support.test:runner:0.5'
testImplementation 'org.mockito:mockito-core:2.18.3'
androidTestImplementation 'com.android.support.test:runner:1.0.2'
androidTestImplementation 'org.hamcrest:hamcrest-library:1.3'
}

Expand Down
11 changes: 3 additions & 8 deletions samples/src/main/AndroidManifest.xml
Expand Up @@ -51,14 +51,6 @@
android:name="com.mcxiaoke.next.samples.AlertDialogSamples"
android:label="@string/app_name" />

<activity
android:name="com.mcxiaoke.next.samples.EndlessListViewSamples"
android:label="@string/app_name" />

<activity
android:name="com.mcxiaoke.next.samples.EndlessRecyclerViewSamples"
android:label="@string/app_name" />

<activity
android:name="com.mcxiaoke.next.samples.ListViewExtendSamples"
android:label="@string/app_name" />
Expand Down Expand Up @@ -97,6 +89,9 @@
<activity
android:name=".http.NextClientSamples"
android:label="@string/app_name" />
<activity
android:name=".RecyclerViewSample"
android:label="@string/app_name" />

</application>
</manifest>
@@ -0,0 +1,181 @@
package com.mcxiaoke.next.samples;

import android.annotation.SuppressLint;
import android.os.Bundle;
import android.os.SystemClock;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.support.v7.widget.RecyclerView.ViewHolder;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import com.mcxiaoke.next.recycler.AdvancedRecyclerArrayAdapter;
import com.mcxiaoke.next.recycler.AdvancedRecyclerView;
import com.mcxiaoke.next.recycler.AdvancedRecyclerView.ItemViewHolder;
import com.mcxiaoke.next.recycler.AdvancedRecyclerView.OnLoadDataListener;
import com.mcxiaoke.next.recycler.AdvancedRecyclerView.ViewHolderCreator;
import com.mcxiaoke.next.task.SimpleTaskCallback;
import com.mcxiaoke.next.task.TaskBuilder;
import com.mcxiaoke.next.utils.LogUtils;

import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import java.util.concurrent.Callable;

/**
* User: mcxiaoke
* Date: 2018/6/17
* Time: 17:53
*/
public class RecyclerViewSample extends BaseActivity {
public static final String TAG = "NextRecyclerViewSample";

private AdvancedRecyclerView recyclerView;
private SampleAdapter arrayAdapter;
private Random random = new Random();
private static int sCounter = 0;

static class SimpleViewHolder extends ItemViewHolder {
private TextView textView;

public SimpleViewHolder(final View itemView) {
super(itemView);
textView = itemView.findViewById(R.id.text1);
}

@SuppressLint("SetTextI18n")
@Override
public void bind(final int position) {
super.bind(position);
textView.setText("Header Text " + position);
}
}

@Override
protected void onCreate(final Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.act_next_recycler_view);

arrayAdapter = new SampleAdapter();
recyclerView = findViewById(R.id.recycler_view);
recyclerView.setAdapter(arrayAdapter);
recyclerView.setEnableHeaderLoading(true);
recyclerView.setEnableFooterLoading(true);
recyclerView.setOnLoadDataListener(new OnLoadDataListener() {
@Override
public void onHeaderLoading(final AdvancedRecyclerView recyclerView) {
addHeaderDataAsync();
}


@Override
public void onFooterLoading(final AdvancedRecyclerView recyclerView) {
addFooterDataAsync();
}
});
recyclerView.addHeader(R.layout.layout_simple_header);
arrayAdapter.addAll(Data.TITLES);
}


private void addHeaderDataAsync() {
TaskBuilder.create(new Callable<List<String>>() {
@Override
public List<String> call() throws Exception {
SystemClock.sleep(random.nextInt(8) * 1000);
return generateData(random.nextInt(30));
}
}).callback(new SimpleTaskCallback<List<String>>() {

@Override
public void onTaskSuccess(final List<String> strings, final Bundle extras) {
super.onTaskSuccess(strings, extras);
LogUtils.i(TAG, "addHeaderDataAsync thread=" + Thread.currentThread());
arrayAdapter.addAll(0, strings);
recyclerView.setHeaderLoading(false);
recyclerView.setEnableHeaderLoading(false);
recyclerView.addHeader(new ViewHolderCreator<ViewHolder>() {
@Override
public ViewHolder create(final ViewGroup parent) {
LayoutInflater inflater = LayoutInflater.from(parent.getContext());
View view = inflater.inflate(R.layout.layout_simple_header, parent, false);
return new SimpleViewHolder(view);
}

@Override
public void bind(final ViewHolder holder, final int position) {

}
});
}

@Override
public void onTaskFailure(final Throwable ex, final Bundle extras) {
super.onTaskFailure(ex, extras);
}
}).with(this).start();
}


private void addFooterDataAsync() {
TaskBuilder.create(new Callable<List<String>>() {
@Override
public List<String> call() throws Exception {
SystemClock.sleep(random.nextInt(8) * 1000);
return generateData(random.nextInt(30));
}
}).callback(new SimpleTaskCallback<List<String>>() {

@Override
public void onTaskSuccess(final List<String> strings, final Bundle extras) {
super.onTaskSuccess(strings, extras);
LogUtils.i(TAG, "addFooterDataAsync thread=" + Thread.currentThread());
arrayAdapter.addAll(strings);
recyclerView.setFooterLoading(false);
if (sCounter > 10) {
recyclerView.addFooter(R.layout.layout_simple_header);
recyclerView.setEnableFooterLoading(false);
}
}

@Override
public void onTaskFailure(final Throwable ex, final Bundle extras) {
super.onTaskFailure(ex, extras);
}
}).with(this).start();
}

private List<String> generateData(int count) {
sCounter++;
final List<String> data = new ArrayList<>();
for (int i = 0; i < 10 + count; i++) {
data.add("List Item AAA " + sCounter + " - No. " + i);
}
return data;
}

static class SampleAdapter extends AdvancedRecyclerArrayAdapter<String, ItemViewHolder> {

@NonNull
@Override
public ItemViewHolder onCreateViewHolder(@NonNull final ViewGroup parent, final int viewType) {
View view = LayoutInflater.from(parent.getContext())
.inflate(android.R.layout.simple_list_item_1, parent, false);
return new ItemViewHolder(view);
}

@Override
public void onBindViewHolder(@NonNull final ItemViewHolder holder, final int position) {
TextView textView = holder.itemView.findViewById(android.R.id.text1);
textView.setText(getItem(position));
}

@Nullable
@Override
public Object getItemId(@NonNull final String item) {
return item;
}
}
}
6 changes: 1 addition & 5 deletions samples/src/main/java/com/mcxiaoke/next/samples/Samples.java
@@ -1,6 +1,5 @@
package com.mcxiaoke.next.samples;

import android.app.TaskStackBuilder;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
Expand Down Expand Up @@ -84,12 +83,11 @@ private void someTest() {

private void initSamples() {
mSampleListData = new ArrayList<>();
mSampleListData.add(new SampleInfo(RecyclerViewSample.TAG, RecyclerViewSample.class));
mSampleListData.add(new SampleInfo(ViewGroupSample.TAG, ViewGroupSample.class));
mSampleListData.add(new SampleInfo(LineLayoutSample.TAG, LineLayoutSample.class));
mSampleListData.add(new SampleInfo(BasicBusSample.TAG, BasicBusSample.class));
mSampleListData.add(new SampleInfo(BasicBusSample2.TAG, BasicBusSample2.class));
mSampleListData.add(new SampleInfo(EndlessRecyclerViewSamples.TAG, EndlessRecyclerViewSamples.class));
mSampleListData.add(new SampleInfo(EndlessListViewSamples.TAG, EndlessListViewSamples.class));
mSampleListData.add(new SampleInfo(ListViewExtendSamples.TAG, ListViewExtendSamples.class));
mSampleListData.add(new SampleInfo(StickyHeaderSamples.TAG, StickyHeaderSamples.class));
mSampleListData.add(new SampleInfo(AlertDialogSamples.TAG, AlertDialogSamples.class));
Expand All @@ -98,8 +96,6 @@ private void initSamples() {

mSampleListData.add(new SampleInfo(BasicBusSample.TAG, BasicBusSample.class));
mSampleListData.add(new SampleInfo(BasicBusSample2.TAG, BasicBusSample2.class));
mSampleListData.add(new SampleInfo(EndlessRecyclerViewSamples.TAG, EndlessRecyclerViewSamples.class));
mSampleListData.add(new SampleInfo(EndlessListViewSamples.TAG, EndlessListViewSamples.class));
mSampleListData.add(new SampleInfo(ListViewExtendSamples.TAG, ListViewExtendSamples.class));
mSampleListData.add(new SampleInfo(StickyHeaderSamples.TAG, StickyHeaderSamples.class));
mSampleListData.add(new SampleInfo(AlertDialogSamples.TAG, AlertDialogSamples.class));
Expand Down
8 changes: 8 additions & 0 deletions samples/src/main/res/layout/act_next_recycler_view.xml
@@ -0,0 +1,8 @@
<?xml version="1.0" encoding="utf-8"?>
<com.mcxiaoke.next.recycler.AdvancedRecyclerView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/recycler_view"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">

</com.mcxiaoke.next.recycler.AdvancedRecyclerView>
2 changes: 1 addition & 1 deletion samples/src/main/res/layout/act_recycler.xml
Expand Up @@ -4,7 +4,7 @@
android:layout_width="match_parent"
android:layout_height="match_parent">

<com.mcxiaoke.next.recycler.EndlessRecyclerView
<com.mcxiaoke.next.recycler.AdvancedRecyclerView
android:id="@android:id/list"
android:layout_height="match_parent"
android:layout_width="match_parent" />
Expand Down
17 changes: 17 additions & 0 deletions samples/src/main/res/layout/layout_simple_header.xml
@@ -0,0 +1,17 @@
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="15dp"
android:gravity="center_vertical">

<TextView
android:id="@+id/text1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="17sp"
android:textStyle="bold"
android:text="@string/share_action_provider_target_not_found" />

</LinearLayout>
2 changes: 1 addition & 1 deletion task/build.gradle
Expand Up @@ -3,7 +3,7 @@ apply plugin: 'com.android.library'
dependencies {
// compile project(":core")
testCompile 'junit:junit:4.12'
testCompile 'org.mockito:mockito-core:1.10.19'
testCompile 'org.mockito:mockito-core:2.18.3'
}

apply from: '../base.gradle'
Expand Down

0 comments on commit b6bc2f5

Please sign in to comment.