Refresh is working
This commit is contained in:
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@@ -62,7 +62,7 @@ public class TSAdapter extends ArrayAdapter<TSjsonAnnouncement> {
|
|||||||
public View getView(int position, View convertView, ViewGroup parent) {
|
public View getView(int position, View convertView, ViewGroup parent) {
|
||||||
ViewHolder holder = null;
|
ViewHolder holder = null;
|
||||||
int type = getItemViewType(position);
|
int type = getItemViewType(position);
|
||||||
if (convertView == null) {
|
if (convertView == null || convertView.getTag() == null) {
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case AnnounceType.REMARK:
|
case AnnounceType.REMARK:
|
||||||
convertView = mInflater.inflate(R.layout.teacher_substitution_row_remark, null);
|
convertView = mInflater.inflate(R.layout.teacher_substitution_row_remark, null);
|
||||||
|
|||||||
@@ -9,9 +9,11 @@ import java.io.StringWriter;
|
|||||||
import java.net.MalformedURLException;
|
import java.net.MalformedURLException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.net.URLConnection;
|
import java.net.URLConnection;
|
||||||
import java.util.concurrent.ExecutionException;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import me.caesar2011.vpherder.R;
|
import me.caesar2011.vpherder.R;
|
||||||
|
import me.caesar2011.vpherder.views.PullToRefreshListView;
|
||||||
|
import me.caesar2011.vpherder.views.PullToRefreshListView.OnRefreshListener;
|
||||||
|
|
||||||
import org.apache.commons.io.IOUtils;
|
import org.apache.commons.io.IOUtils;
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
@@ -21,7 +23,6 @@ import android.os.AsyncTask;
|
|||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.widget.ListView;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class to organize the drawings of the teacher substition.
|
* Class to organize the drawings of the teacher substition.
|
||||||
@@ -35,6 +36,9 @@ public class TSCreate {
|
|||||||
private final LayoutInflater inflater;
|
private final LayoutInflater inflater;
|
||||||
private final ViewGroup container;
|
private final ViewGroup container;
|
||||||
private static TSjsonObject JsonObject;
|
private static TSjsonObject JsonObject;
|
||||||
|
private boolean downloadStarted;
|
||||||
|
private TSAdapter adapter;
|
||||||
|
private PullToRefreshListView listview;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
@@ -43,26 +47,10 @@ public class TSCreate {
|
|||||||
this.activity = activity;
|
this.activity = activity;
|
||||||
this.inflater = inflater;
|
this.inflater = inflater;
|
||||||
this.container = container;
|
this.container = container;
|
||||||
|
this.downloadStarted = false;
|
||||||
|
|
||||||
if(JsonObject == null){
|
if(JsonObject == null){
|
||||||
try {
|
StartDownload();
|
||||||
URL url = new URL("https://vpherder.canis.uberspace.de/example.json");
|
|
||||||
|
|
||||||
DownloadFilesTask downloadSubstitutions = new DownloadFilesTask();
|
|
||||||
downloadSubstitutions.execute(url);
|
|
||||||
downloadSubstitutions.get();
|
|
||||||
String theString = downloadSubstitutions.getOutput()[0];
|
|
||||||
|
|
||||||
JsonObject = new TSjsonObject(theString);
|
|
||||||
} catch (ExecutionException e) {
|
|
||||||
System.out.println("ERRRRRRRRRRRRRRRRRRRRROR ExecutionException!");
|
|
||||||
} catch (InterruptedException e) {
|
|
||||||
System.out.println("ERRRRRRRRRRRRRRRRRRRRROR InterruptedException!");
|
|
||||||
} catch (JSONException e) {
|
|
||||||
System.out.println("ERRRRRRRRRRRRRRRRRRRRROR JSONException!");
|
|
||||||
} catch (MalformedURLException e) {
|
|
||||||
System.out.println("ERRRRRRRRRRRRRRRRRRRRROR MalformedURLException!");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -70,49 +58,71 @@ public class TSCreate {
|
|||||||
View rootView = inflater.inflate(R.layout.fragment_teacher_substitution,
|
View rootView = inflater.inflate(R.layout.fragment_teacher_substitution,
|
||||||
container, false);
|
container, false);
|
||||||
|
|
||||||
final ListView listview = (ListView) rootView.findViewById(R.id.listview);
|
listview = (PullToRefreshListView) rootView.findViewById(R.id.listview);
|
||||||
|
listview.setOnRefreshListener(new OnRefreshListener() {
|
||||||
|
|
||||||
final TSAdapter adapter = new TSAdapter(activity,
|
@Override
|
||||||
R.layout.teacher_substitution_row_remark, JsonObject.announcements);
|
public void onRefresh() {
|
||||||
|
StartDownload();
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
System.out.println(JsonObject);
|
||||||
|
adapter = new TSAdapter(activity,
|
||||||
|
R.layout.teacher_substitution_row_remark, (JsonObject!=null)?JsonObject.announcements:(new ArrayList<TSjsonAnnouncement>()));
|
||||||
listview.setAdapter(adapter);
|
listview.setAdapter(adapter);
|
||||||
|
|
||||||
return rootView;
|
return rootView;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void StartDownload() {
|
||||||
|
if (!downloadStarted) {
|
||||||
|
downloadStarted = true;
|
||||||
|
try {
|
||||||
|
URL url = new URL("https://vpherder.canis.uberspace.de/example.json");
|
||||||
|
DownloadFilesTask downloadSubstitutions = new DownloadFilesTask();
|
||||||
|
downloadSubstitutions.execute(url);
|
||||||
|
} catch (MalformedURLException e) {
|
||||||
|
downloadStarted = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void FinishDownload() {
|
||||||
|
downloadStarted = false;
|
||||||
|
adapter.clear();
|
||||||
|
adapter.addAll(JsonObject.announcements);
|
||||||
|
adapter.notifyDataSetChanged();
|
||||||
|
listview.onRefreshComplete();
|
||||||
|
}
|
||||||
|
|
||||||
private class DownloadFilesTask extends AsyncTask<URL, Integer, String[]> {
|
private class DownloadFilesTask extends AsyncTask<URL, Integer, String> {
|
||||||
private String[] outputFiles;
|
|
||||||
|
|
||||||
protected String[] doInBackground(URL... urls) {
|
protected String doInBackground(URL... urls) {
|
||||||
int count = urls.length;
|
String file = "";
|
||||||
String[] files = new String[count];
|
URL url = urls[0];
|
||||||
for (int i = 0; i < count; i++) {
|
|
||||||
URLConnection connection;
|
URLConnection connection;
|
||||||
try {
|
try {
|
||||||
connection = urls[i].openConnection();
|
connection = url.openConnection();
|
||||||
InputStream inputStream = connection.getInputStream();
|
InputStream inputStream = connection.getInputStream();
|
||||||
publishProgress((int) ((i / (float) count) * 100));
|
|
||||||
|
|
||||||
StringWriter writer = new StringWriter();
|
StringWriter writer = new StringWriter();
|
||||||
IOUtils.copy(inputStream, writer, "UTF-8");
|
IOUtils.copy(inputStream, writer, "UTF-8");
|
||||||
files[i] = writer.toString();
|
file = writer.toString();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
}
|
}
|
||||||
|
return file;
|
||||||
// Escape early if cancel() is called
|
|
||||||
if (isCancelled()) break;
|
|
||||||
}
|
|
||||||
outputFiles = files;
|
|
||||||
return files;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void onProgressUpdate(Integer... progress) {
|
protected void onProgressUpdate(Integer... progress) {
|
||||||
//setProgressPercent(progress[0]);
|
//setProgressPercent(progress[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String[] getOutput() {
|
protected void onPostExecute(String result) {
|
||||||
return outputFiles;
|
try {
|
||||||
|
JsonObject = new TSjsonObject(result);
|
||||||
|
} catch (JSONException e) {
|
||||||
|
}
|
||||||
|
FinishDownload();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -21,6 +21,7 @@ public class PullToRefreshListView extends ListView implements OnScrollListener
|
|||||||
private View mHeaderView;
|
private View mHeaderView;
|
||||||
private HeaderViewHolder mHeaderViewHolder;
|
private HeaderViewHolder mHeaderViewHolder;
|
||||||
private int mLastTopVisiblePos;
|
private int mLastTopVisiblePos;
|
||||||
|
private OnRefreshListener mOnRefreshListener;
|
||||||
|
|
||||||
private static final int PULL_DOWN_LIMIT = (int) Math.round(0.75 * DisplayMetrics.DENSITY_DEFAULT);
|
private static final int PULL_DOWN_LIMIT = (int) Math.round(0.75 * DisplayMetrics.DENSITY_DEFAULT);
|
||||||
|
|
||||||
@@ -48,6 +49,7 @@ public class PullToRefreshListView extends ListView implements OnScrollListener
|
|||||||
mHeaderView = mInflater.inflate(R.layout.pull_to_refresh_header, null);
|
mHeaderView = mInflater.inflate(R.layout.pull_to_refresh_header, null);
|
||||||
mHeaderViewHolder = new HeaderViewHolder(mHeaderView);
|
mHeaderViewHolder = new HeaderViewHolder(mHeaderView);
|
||||||
addHeaderView(mHeaderView);
|
addHeaderView(mHeaderView);
|
||||||
|
System.out.println("k"+mHeaderView);
|
||||||
|
|
||||||
mRefreshState = RefreshState.PULL_TO_REFRESH;
|
mRefreshState = RefreshState.PULL_TO_REFRESH;
|
||||||
}
|
}
|
||||||
@@ -68,7 +70,7 @@ public class PullToRefreshListView extends ListView implements OnScrollListener
|
|||||||
boolean isHandled = false;
|
boolean isHandled = false;
|
||||||
|
|
||||||
if (event.getAction() == MotionEvent.ACTION_DOWN || mLastTopVisiblePos == 1) {
|
if (event.getAction() == MotionEvent.ACTION_DOWN || mLastTopVisiblePos == 1) {
|
||||||
int refreshBoxHeight = (int) ((mRefreshState == RefreshState.REFRESHING)?PULL_DOWN_LIMIT+15:1);
|
int refreshBoxHeight = (int) ((mRefreshState == RefreshState.REFRESHING)?PULL_DOWN_LIMIT:1);
|
||||||
mStartX = event.getRawX();
|
mStartX = event.getRawX();
|
||||||
mStartY = event.getRawY()-refreshBoxHeight;
|
mStartY = event.getRawY()-refreshBoxHeight;
|
||||||
mHeaderViewHolder.setVisibility(View.VISIBLE);
|
mHeaderViewHolder.setVisibility(View.VISIBLE);
|
||||||
@@ -76,9 +78,6 @@ public class PullToRefreshListView extends ListView implements OnScrollListener
|
|||||||
}
|
}
|
||||||
if (event.getRawY()-mStartY > Math.abs(event.getRawX()-mStartX) && getFirstVisiblePosition() == 0) {
|
if (event.getRawY()-mStartY > Math.abs(event.getRawX()-mStartX) && getFirstVisiblePosition() == 0) {
|
||||||
int stretch = (int) Math.max(0, event.getRawY()-mStartY);
|
int stretch = (int) Math.max(0, event.getRawY()-mStartY);
|
||||||
System.out.println(event.getRawY()-mStartY);
|
|
||||||
System.out.println(Math.abs(event.getRawX()-mStartX));
|
|
||||||
System.out.println("--");
|
|
||||||
mHeaderView.setLayoutParams(new LayoutParams(mHeaderView.getLayoutParams().width, stretch));
|
mHeaderView.setLayoutParams(new LayoutParams(mHeaderView.getLayoutParams().width, stretch));
|
||||||
if (mRefreshState == RefreshState.PULL_TO_REFRESH && stretch > PULL_DOWN_LIMIT) {
|
if (mRefreshState == RefreshState.PULL_TO_REFRESH && stretch > PULL_DOWN_LIMIT) {
|
||||||
mRefreshState = RefreshState.RELEASE_TO_REFRESH;
|
mRefreshState = RefreshState.RELEASE_TO_REFRESH;
|
||||||
@@ -89,7 +88,7 @@ public class PullToRefreshListView extends ListView implements OnScrollListener
|
|||||||
} else if (mRefreshState == RefreshState.ABORTING && stretch > PULL_DOWN_LIMIT) {
|
} else if (mRefreshState == RefreshState.ABORTING && stretch > PULL_DOWN_LIMIT) {
|
||||||
mRefreshState = RefreshState.RELEASE_TO_REFRESH;
|
mRefreshState = RefreshState.RELEASE_TO_REFRESH;
|
||||||
mHeaderViewHolder.setRefreshingState(mRefreshState);
|
mHeaderViewHolder.setRefreshingState(mRefreshState);
|
||||||
} else if (mRefreshState == RefreshState.REFRESHING && stretch <= PULL_DOWN_LIMIT) {
|
} else if (mRefreshState == RefreshState.REFRESHING && stretch <= PULL_DOWN_LIMIT/2) {
|
||||||
mRefreshState = RefreshState.ABORTING;
|
mRefreshState = RefreshState.ABORTING;
|
||||||
mHeaderViewHolder.setRefreshingState(mRefreshState);
|
mHeaderViewHolder.setRefreshingState(mRefreshState);
|
||||||
}
|
}
|
||||||
@@ -104,10 +103,7 @@ public class PullToRefreshListView extends ListView implements OnScrollListener
|
|||||||
mHeaderView.setLayoutParams(new LayoutParams(mHeaderView.getLayoutParams().width, 0));
|
mHeaderView.setLayoutParams(new LayoutParams(mHeaderView.getLayoutParams().width, 0));
|
||||||
break;
|
break;
|
||||||
case RefreshState.RELEASE_TO_REFRESH:
|
case RefreshState.RELEASE_TO_REFRESH:
|
||||||
mHeaderViewHolder.setVisibility(View.VISIBLE);
|
Refresh();
|
||||||
mRefreshState = RefreshState.REFRESHING;
|
|
||||||
mHeaderViewHolder.setRefreshingState(mRefreshState);
|
|
||||||
mHeaderView.setLayoutParams(new LayoutParams(mHeaderView.getLayoutParams().width, PULL_DOWN_LIMIT));
|
|
||||||
break;
|
break;
|
||||||
case RefreshState.REFRESHING:
|
case RefreshState.REFRESHING:
|
||||||
mHeaderView.setLayoutParams(new LayoutParams(mHeaderView.getLayoutParams().width, PULL_DOWN_LIMIT));
|
mHeaderView.setLayoutParams(new LayoutParams(mHeaderView.getLayoutParams().width, PULL_DOWN_LIMIT));
|
||||||
@@ -162,4 +158,30 @@ public class PullToRefreshListView extends ListView implements OnScrollListener
|
|||||||
public static final int REFRESHING = 3;
|
public static final int REFRESHING = 3;
|
||||||
public static final int ABORTING = 4;
|
public static final int ABORTING = 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void Refresh() {
|
||||||
|
mHeaderViewHolder.setVisibility(View.VISIBLE);
|
||||||
|
mRefreshState = RefreshState.REFRESHING;
|
||||||
|
mHeaderViewHolder.setRefreshingState(mRefreshState);
|
||||||
|
mHeaderView.setLayoutParams(new LayoutParams(mHeaderView.getLayoutParams().width, PULL_DOWN_LIMIT));
|
||||||
|
System.out.print("onRefresh");
|
||||||
|
if (mOnRefreshListener != null) {
|
||||||
|
mOnRefreshListener.onRefresh();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setOnRefreshListener(OnRefreshListener onRefreshListener) {
|
||||||
|
mOnRefreshListener = onRefreshListener;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onRefreshComplete() {
|
||||||
|
mHeaderViewHolder.setVisibility(View.GONE);
|
||||||
|
mRefreshState = RefreshState.PULL_TO_REFRESH;
|
||||||
|
mHeaderViewHolder.setRefreshingState(mRefreshState);
|
||||||
|
mHeaderView.setLayoutParams(new LayoutParams(mHeaderView.getLayoutParams().width, 0));
|
||||||
|
}
|
||||||
|
|
||||||
|
public interface OnRefreshListener {
|
||||||
|
public void onRefresh();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user