Android实现数据库填充无聚合新闻次数下的标题点击新闻对应类型(简易新闻 十四)
关于
本篇讲的在聚合新闻api访问次数用完后,使用远程mysql数据库内容填充显示后。这句话是前提即简易新闻系列文章中早已实现,本篇要讲的是在这个基础上点击对应标题实现加载对应标题类型的新闻,如点击社会就显示社会新闻,下拉刷新也是一样的。
效果如下:
实现
通过点击标题获取对应标题value值然后转换后作为sql语句的where判定条件进行select,代码如下:
第一步,修改NewsFragment.java
package com.example.frametest;
import android.annotation.SuppressLint;
import android.content.Intent;
import android.os.AsyncTask;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.support.design.widget.FloatingActionButton;
import android.support.v4.app.Fragment;
import android.support.v4.widget.SwipeRefreshLayout;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.Toast;
import com.example.frametest.json.NewsBean;
import com.example.frametest.TabAdapter.MyTabAdapter;
import com.example.frametest.tools.DBOpenHelper;
import com.example.frametest.tools.MyApplication;
import com.example.frametest.tools.NetworkStateUtil;
import com.google.gson.Gson;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
import static interfaces.heweather.com.interfacesmodule.view.HeContext.context;
public class NewsFragment extends Fragment {
private FloatingActionButton fab;
private ListView listView;
private SwipeRefreshLayout swipeRefreshLayout;
private List<NewsBean.ResultBean.DataBean> list;
private static final int UPNEWS_INSERT = 0;
private int page =0,row =10;
private static final int SELECT_REFLSH = 1;
private static final int NO_NETWORK = 1001;
String responseDate;
String dataChina ="头条" ;
@SuppressLint("HandlerLeak")
private Handler newsHandler = new Handler(){
@Override
public void handleMessage(Message msg) {
String uniquekey,title,date, category,author_name,url,thumbnail_pic_s,thumbnail_pic_s02,thumbnail_pic_s03;
switch (msg.what){
case UPNEWS_INSERT:
list = ((NewsBean) msg.obj).getResult().getData();
MyTabAdapter adapter = new MyTabAdapter(getActivity(),list);
listView.setAdapter(adapter);
adapter.notifyDataSetChanged();
break;
case SELECT_REFLSH:
list =((NewsBean) msg.obj).getResult().getData();
MyTabAdapter myTabAdapter = new MyTabAdapter(getActivity(),list);
listView.setAdapter(myTabAdapter);
myTabAdapter.notifyDataSetChanged();
if (swipeRefreshLayout.isRefreshing()){
swipeRefreshLayout.setRefreshing(false);//设置不刷新
}
break;
case NO_NETWORK:
Toast.makeText(context,"请检查手机网络连接", Toast.LENGTH_SHORT).show();
lay_empty.setVisibility(View.VISIBLE);
listView.setEmptyView( lay_empty);
if (swipeRefreshLayout.isRefreshing()){
swipeRefreshLayout.setRefreshing(false);//设置不刷新
}
break;
default:
}
}
};
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
}
@Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.list_item,container,false);
listView = (ListView) view.findViewById(R.id.listView);
fab = (FloatingActionButton) view.findViewById(R.id.fab);
swipeRefreshLayout = (SwipeRefreshLayout) view.findViewById(R.id.swipe_refresh);
return view;
}
@SuppressLint("HandlerLeak")
@Override
public void onActivityCreated(@Nullable Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
onAttach(getActivity());
//获取传递的值
Bundle bundle = getArguments();
final String data = bundle.getString("name","top");
//置顶功能
fab.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
listView.smoothScrollToPosition(0);
}
});
//下拉刷新
swipeRefreshLayout.setColorSchemeResources(R.color.colorRed);
swipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
@Override
public void onRefresh() {
page++;
//通过获取传值的bundle值进行判断转换
if (data.equals("guoji")){
dataChina ="国际";
}else if (data.equals("tiyu")){
dataChina ="体育";
}else if (data.equals("yule")){
dataChina ="娱乐";
}else if (data.equals("caijing")){
dataChina ="财经";
}else if (data.equals("keji")){
dataChina ="科技";
}else if (data.equals("guonei")){
dataChina ="国内";
}else if (data.equals("shehui")){
dataChina ="社会";
}else if (data.equals("junshi")){
dataChina ="军事";
}
// 下一步实现从数据库中读取数据刷新到listview适配器中
new Thread(new Runnable() {
@Override
public void run() {
NewsBean newsBean = new NewsBean();
List<NewsBean.ResultBean.DataBean> dataBeanList = new ArrayList<>();
Connection conn = null;
conn = (Connection) DBOpenHelper.getConn();
int pages = (page -1)*row;
//对应每次查询第几项以及查询的类型
String sql = "select *from news_info where category='"+dataChina+"' limit "+pages+","+row;
PreparedStatement pst;
try {
pst = (PreparedStatement) conn.prepareStatement(sql);
ResultSet rs = pst.executeQuery();
while (rs.next()){
NewsBean.ResultBean.DataBean dataBean = new NewsBean.ResultBean.DataBean();
dataBean.setUniquekey(rs.getString(1));
dataBean.setTitle(rs.getString(2));
dataBean.setDate(rs.getString(3));
dataBean.setCategory(rs.getString(4));
dataBean.setAuthor_name(rs.getString(5));
dataBean.setUrl(rs.getString(6));
dataBean.setThumbnail_pic_s(rs.getString(7));
dataBean.setThumbnail_pic_s02(rs.getString(8));
dataBean.setThumbnail_pic_s03(rs.getString(9));
dataBeanList.add(dataBean);
}
newsBean.setResult(new NewsBean.ResultBean());
newsBean.getResult().setData(dataBeanList);
pst.close();
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
Message msg = newsHandler.obtainMessage();
msg.what = SELECT_REFLSH;
msg.obj = newsBean;
newsHandler.sendMessage(msg);
}
}).start();
}
});
//异步加载数据
getDataFromNet(data);
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
//获取点击条目的路径,传值显示webview页面
String url = list.get(position).getUrl();
String uniquekey = list.get(position).getUniquekey();
// final NewsBean.ResultBean.DataBean dataBean = (NewsBean.ResultBean.DataBean) list.get(position);
//这里是在listview子item的点击事件中添加一个插入新闻的具体json数据到news_info表中
/* new Thread(new Runnable() {
@Override
public void run() {
Connection conn = null;
conn = (Connection) DBOpenHelper.getConn();
System.out.print(conn);
String sql = "insert into news_info(uniquekey,title,date,category,author_name,url,thumbnail_pic_s,thumbnail_pic_s02,thumbnail_pic_s03) values(?,?,?,?,?,?,?,?,?)";
int i = 0;
PreparedStatement pstmt;
try {
pstmt = (PreparedStatement) conn.prepareStatement(sql);
pstmt.setString(1,dataBean.getUniquekey());
pstmt.setString(2,dataBean.getTitle());
pstmt.setString(3,dataBean.getDate());
pstmt.setString(4,dataBean.getCategory());
pstmt.setString(5,dataBean.getAuthor_name());
pstmt.setString(6,dataBean.getUrl());
pstmt.setString(7,dataBean.getThumbnail_pic_s());
pstmt.setString(8,dataBean.getThumbnail_pic_s02());
pstmt.setString(9,dataBean.getThumbnail_pic_s03());
i = pstmt.executeUpdate();
pstmt.close();
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}).start();*/
Intent intent = new Intent(getActivity(),WebActivity.class);
intent.putExtra("url",url);
intent.putExtra("uniquekey",uniquekey);
startActivity(intent);
}
});
}
private void getDataFromNet(final String data){
final String path = "http://v.juhe.cn/toutiao/index?type="+data+"&key=547ee75ef186fc55a8f015e38dcfdb9a";
new Thread(new Runnable() {
@Override
public void run() {
OkHttpClient okHttpClient = new OkHttpClient();
Request request = new Request.Builder()
.url(path)
.build();
try {
Response response = okHttpClient.newCall(request).execute();
responseDate = response.body().string();
NewsBean newsBean = new Gson().fromJson(responseDate, NewsBean.class);
System.out.println("获取到的json数据新闻内容:"+responseDate);
System.out.println("获取到的json数据新闻解析内容:"+newsBean.getError_code());
if ("10012".equals("" + newsBean.getError_code())) {
//当聚合新闻api无访问次数的时候会报这个10012code,这时候我们就可以对应根据date来进行转换查询
List<NewsBean.ResultBean.DataBean> listDataBean = new ArrayList<>();
Connection conn = null;
if (data.equals("guoji")){
dataChina ="国际";
}else if (data.equals("tiyu")){
dataChina ="体育";
}else if (data.equals("yule")){
dataChina ="娱乐";
}else if (data.equals("caijing")){
dataChina ="财经";
}else if (data.equals("keji")){
dataChina ="科技";
}else if (data.equals("guonei")){
dataChina ="国内";
}else if (data.equals("shehui")){
dataChina ="社会";
}else if (data.equals("junshi")){
dataChina ="军事";
}
conn = (Connection) DBOpenHelper.getConn();
String sql = "select * from news_info where category='"+dataChina+"'";
PreparedStatement pstmt;
pstmt = (PreparedStatement) conn.prepareStatement(sql);
ResultSet rs = pstmt.executeQuery();
while (rs.next()) {
NewsBean.ResultBean.DataBean dataBean = new NewsBean.ResultBean.DataBean();
dataBean.setUniquekey(rs.getString(1));
dataBean.setTitle(rs.getString(2));
dataBean.setDate(rs.getString(3));
dataBean.setCategory(rs.getString(4));
dataBean.setAuthor_name(rs.getString(5));
dataBean.setUrl(rs.getString(6));
dataBean.setThumbnail_pic_s(rs.getString(7));
dataBean.setThumbnail_pic_s02(rs.getString(8));
dataBean.setThumbnail_pic_s03(rs.getString(9));
listDataBean.add(dataBean);
}
newsBean.setResult(new NewsBean.ResultBean());
newsBean.getResult().setData(listDataBean);
pstmt.close();
conn.close();
}
JSONObject jsonObject =null;
try {
jsonObject = new JSONObject(responseDate);
JSONObject jsonObject1 = jsonObject.getJSONObject("result");
JSONArray jsonArray = jsonObject1.getJSONArray("data");
for (int i=0;i<jsonArray.length();i++){
JSONObject jsonObject2 = jsonArray.getJSONObject(i);
//这里是在新闻类别的点击事件中添加一个插入新闻的具体json数据到news_info表中
new Thread(new Runnable() {
@Override
public void run() {
Connection conn = null;
conn = (Connection) DBOpenHelper.getConn();
System.out.print(conn);
String sql = "insert into news_info(uniquekey,title,date,category,author_name,url,thumbnail_pic_s,thumbnail_pic_s02,thumbnail_pic_s03) values(?,?,?,?,?,?,?,?,?)";
int i = 0;
PreparedStatement pstmt;
try {
pstmt = (PreparedStatement) conn.prepareStatement(sql);
pstmt.setString(1,jsonObject2.getString("uniquekey"));
pstmt.setString(2,jsonObject2.getString("title"));
pstmt.setString(3,jsonObject2.getString("date"));
pstmt.setString(4,jsonObject2.getString("category"));
pstmt.setString(5,jsonObject2.getString("author_name"));
pstmt.setString(6,jsonObject2.getString("url"));
pstmt.setString(7,jsonObject2.getString("thumbnail_pic_s"));
pstmt.setString(8,jsonObject2.getString("thumbnail_pic_s02"));
pstmt.setString(9,jsonObject2.getString("thumbnail_pic_s03"));
i = pstmt.executeUpdate();
pstmt.close();
conn.close();
} catch (SQLException e) {
e.printStackTrace();
} catch (JSONException e) {
e.printStackTrace();
}
}
}).start();
}
} catch (JSONException e) {
e.printStackTrace();
}
Message msg = newsHandler.obtainMessage();
msg.what = UPNEWS_INSERT;
msg.obj = newsBean;
newsHandler.sendMessage(msg);
} catch (IOException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
}
}).start();
}
private String streamToString(InputStream inputStream, String charset){
try {
InputStreamReader inputStreamReader = new InputStreamReader(inputStream,charset);
BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
String s = null;
StringBuilder builder = new StringBuilder();
while ((s = bufferedReader.readLine()) != null){
builder.append(s);
}
bufferedReader.close();
return builder.toString();
} catch (IOException e) {
e.printStackTrace();
}
return null;
}
}
好啦,本篇到此就结束啦,下篇会有其他的一些优化或者功能。有问题欢迎批评指正!
下一篇:Android使用第三方弹出框Sweet Alert Dialog实现退出app (简易新闻 (十五))