我正在为学校报纸创建一个应用程序,并在尝试显示完整文章时遇到问题。目前,我有一个从RSS源中提取的文章列表,当点击一个文章时,它会显示文章的内容。但是只有第一段显示在TextView中,无论它有多长。这让我觉得它与<p></p>
HTML标记有关。我不熟悉RSS提要或解析XML(这是我第一次尝试它)并且已经四处寻找方法去做我想要完成的事情。
我将此项目基于此博客的一系列帖子:http://android-er.blogspot.com/2010/04/simple-rss-reader-in-listview.html
我参加了此处提供的项目,并将其添加到带有滑动模板的标签中,并更改了部分元素的布局方式。
DISCLAMER:有很多评论丑陋的代码,我懒得拿出来。这主要是我在布局中不想要的东西。 这是包含文章列表的片段:
public class AllStoriesFragment extends ListFragment {
/*********************************************************************
* RSS Async Task
*********************************************************************/
public class RssLoadingTask extends AsyncTask<Void, Void, Void> {
@Override
protected void onPostExecute(Void result) {
// TODO Auto-generated method stub
displayRss();
}
@Override
protected void onPreExecute() {
// TODO Auto-generated method stub
preReadRss();
}
@Override
protected void onProgressUpdate(Void... values) {
// TODO Auto-generated method stub
//super.onProgressUpdate(values);
}
@Override
protected Void doInBackground(Void... arg0) {
// TODO Auto-generated method stub
readRss();
return null;
}
}
/*********************************************************************
* End RSS Async Task
*********************************************************************/
private RSSFeed myRssFeed = null;
TextView feedTitle;
TextView feedDescription;
//TextView feedPubdate;
TextView feedLink;
//TextView feedContent;
/*********************************************************************
* Custom Array Adapter
*********************************************************************/
public class MyCustomAdapter extends ArrayAdapter<RSSItem> {
public MyCustomAdapter(Context context, int textViewResourceId,
List<RSSItem> list) {
super(context, textViewResourceId, list);
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
// TODO Auto-generated method stub
//return super.getView(position, convertView, parent);
View row = convertView;
if(row==null){
LayoutInflater inflater=getActivity().getLayoutInflater();
row=inflater.inflate(R.layout.row, parent, false);
}
TextView listTitle=(TextView)row.findViewById(R.id.listtitle);
listTitle.setText(myRssFeed.getList().get(position).getTitle());
TextView listPubdate=(TextView)row.findViewById(R.id.listpubdate);
listPubdate.setText(myRssFeed.getList().get(position).getPubdate());
if (position%2 == 0){
listTitle.setBackgroundColor(0xff101010);
listPubdate.setBackgroundColor(0xff101010);
}
else{
listTitle.setBackgroundColor(0xff080808);
listPubdate.setBackgroundColor(0xff080808);
}
return row;
}
}
/*********************************************************************
* End Custom Array Adapter
*********************************************************************/
/** Called when the fragment is first created. */
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
// Inflate the layout for this fragment
View v = inflater.inflate(R.layout.fragment_allstories, null);;
feedTitle = (TextView)v.findViewById(R.id.feedtitle);
feedDescription = (TextView)v.findViewById(R.id.feeddescription);
//feedPubdate = (TextView)v.findViewById(R.id.feedpubdate);
feedLink = (TextView)v.findViewById(R.id.feedlink);
startReadRss();
return v ;
}
private void startReadRss(){
new RssLoadingTask().execute();
}
private void preReadRss(){
setListAdapter(null);
Toast.makeText(getActivity(), "Reading RSS, Please wait.", Toast.LENGTH_LONG).show();
}
private void readRss(){
try {
URL rssUrl = new URL("http://www.campusslate.com/feed/");
SAXParserFactory mySAXParserFactory = SAXParserFactory.newInstance();
SAXParser mySAXParser = mySAXParserFactory.newSAXParser();
XMLReader myXMLReader = mySAXParser.getXMLReader();
RSSHandler myRSSHandler = new RSSHandler();
myXMLReader.setContentHandler(myRSSHandler);
InputSource myInputSource = new InputSource(rssUrl.openStream());
myXMLReader.parse(myInputSource);
myRssFeed = myRSSHandler.getFeed();
}
catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
private void displayRss(){
if (myRssFeed!=null){
MyCustomAdapter adapter = new MyCustomAdapter(getActivity(), R.layout.row, myRssFeed.getList());
setListAdapter(adapter);
}
}
public void onListItemClick(ListView l, View v, int position, long id) {
// TODO Auto-generated method stub
Intent intent = new Intent(getActivity(), ShowDetails.class);
intent.putExtra("keyPubdate", myRssFeed.getItem(position).getPubdate());
intent.putExtra("keyLink", myRssFeed.getItem(position).getLink());
intent.putExtra("keyTitle", myRssFeed.getItem(position).getTitle());
intent.putExtra("keyContent", myRssFeed.getItem(position).getContent());
startActivity(intent);
}
public boolean onCreateOptionsMenu(Menu menu) {
// TODO Auto-generated method stub
menu.add(0, 0, 0, "Reload");
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// TODO Auto-generated method stub
switch(item.getItemId()){
case (0): startReadRss();
break;
default:
break;
}
return true;
}
}
这是单击列表中的项目时启动的活动:
package com.nick.pocketslate;
import android.app.Activity;
import android.os.Bundle;
import android.text.Html;
import android.text.method.ScrollingMovementMethod;
import android.widget.TextView;
public class ShowDetails extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.details);
TextView detailsTitle = (TextView)findViewById(R.id.detailstitle);
TextView detailsPubdate = (TextView)findViewById(R.id.detailspubdate);
TextView detailsLink = (TextView)findViewById(R.id.detailslink);
TextView detailsContent = (TextView)findViewById(R.id.detailscontent);
Intent intent = getIntent();
detailsTitle.setText(intent.getStringExtra("keyTitle"));
detailsPubdate.setText(intent.getStringExtra("keyPubdate"));
detailsLink.setText(intent.getStringExtra("keyLink"));
detailsContent.setText(Html.fromHtml(intent.getStringExtra("keyContent")));
detailsContent.setMovementMethod(new ScrollingMovementMethod());
}
}
此时我已经做了很多搜索并且没有找到解决方案,我不确定我的代码的哪一部分可能导致问题。我有一个链接可以在这里下载我的完整项目,如果有人可以看看并找到问题。
如果有人知道从哪里开始寻找,我会提出这段代码。
答案 0 :(得分:0)
您展示的内容看起来是正确的,但您的模型的代码在哪里 - RSSFeed?您可能希望获得一些调试输出,以显示您的RSS阅读是否正常运行。也许你只是得到摘要而不是完整的文章?也许完整的文章应该从它自己的链接中读取,而不是从精简的RSS提要中读取?
对于HTML内容,您通常使用LinkMovementMethod,因此内容中的链接可以正确处理。假设您尚未设置TextView.maxLines属性(可能需要检查),TextView会自动滚动。
另外,为简单起见,您应该直接从Intent添加/读取数据 - 实际上不需要通过中间Bundle。 putExtra(String,String)和getStringExtra(String)或者你可以使用它们的CharSequence等价物,具体取决于从RSSReader输出的确切内容。
编辑:您是否正在检查TextView是否正常滚动显示长度超过5行的虚拟文字?您还可以尝试外部复制Feed中的内容数据(通过外部Feed阅读器)并使用TextView.setText(CharSequence)将其明确地放入TextView中,以检查Feed中的某些内容是否导致您的问题。
(Html.fromHtml基于TagSoup,它设计用于处理格式不佳的HTML,但您总是可以尝试使用纯文本进行测试,看看是否有效。您还可以使用调试日志/ LogCat来检查HTML解析RSS feed内容之前/之后。)
如果这些问题有问题,那么TextView布局/初始化可能会出现问题。如果这些事情都有效,那么您就知道问题出在与RSS相关的代码中。
您可以发布详细视图的布局代码吗?此外,您使用的是模拟器还是实际的手机?有时,模拟器不会像实际设备那样响应滚动手势。
编辑:如果是问题的RSSHandler,我建议创建一个适当标记的单独/新问题(SAX,XML-Parser,RSS)。如果你在这里发布一个新问题的链接,我可以尝试在那里提供帮助。您还可以尝试首先查找可能有助于SAX XML解析方法的特定答案。这是我最近一直在使用的一个很好的教程 - http://tutorials.jenkov.com/java-xml/sax.html