[英]Android TextView cuts off after one paragraph
我正在为学校报纸创建一个应用程序,并且在尝试显示全文时遇到问题。 目前,我有从RSS提要中拉出的文章列表,当单击它时,将显示该文章的内容。 但是,无论多长时间,只有第一段显示在TextView中。 这也使我相信,它与<p></p>
HTML标记有关。 我对RSS提要或解析XML并不熟悉(这是我第一次尝试),并四处寻找实现我要完成的目标的方法。
我基于此博客中的一系列帖子构建了该项目: http : //android-er.blogspot.com/2010/04/simple-rss-reader-in-listview.html
我接受了此处提供的项目,并将其添加到带有滑动模板的选项卡中,并更改了某些元素的布局方式。
免责声明:我有很多评论过的丑陋代码,我懒得拿出来。 这主要是我不想在布局中使用的内容。 这是包含文章列表的片段:
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());
}
}
在这一点上,我已经做了很多搜索,但是还没有找到解决方案,而且我不确定代码的哪一部分会引起问题。 如果有人可以查找并找到问题,我这里有一个链接可以下载我的完整项目。
如果有人对从哪里开始有什么了解,我将提供该部分代码。
您所显示的内容看起来正确,但是模型的代码在哪里-RSSFeed? 您可能需要获取一些调试输出,以显示您的RSS读取是否正常。 也许您只获得摘要而不是全文? 也许应该从其自己的链接而不是删节的RSS feed中阅读全文?
对于HTML内容,通常使用LinkMovementMethod ,因此可以正确处理内容中的链接。 假设您尚未设置TextView.maxLines属性(可能要检查一下),则TextViews将自动滚动。
另外,为简单起见,您只应直接从Intent添加/读取数据-确实不需要通过中间捆绑包。 putExtra(String,String)和getStringExtra(String) ,也可以使用它们的CharSequence等效项,具体取决于RSSReader的输出内容。
编辑:您是否在检查TextView滚动正常显示超过5行的虚拟文本? 您还可以尝试从外部复制Feed中的Content数据(通过外部Feed阅读器),并使用TextView.setText(CharSequence)将其明确地放入TextView中,以检查Feed本身是否引起了问题。
(Html.fromHtml基于TagSoup,旨在处理甚至格式不正确的HTML,但是您始终可以尝试使用纯文本进行测试,看看是否可行。您还可以使用调试日志/ LogCat来检查之前/在HTML解析RSS feed内容之后。)
如果这些事情有问题,则可能是您的TextView布局/初始化有问题。 如果这些都正常,那么您就知道问题出在与RSS相关的代码中。
您可以发布详细视图的布局代码吗? 另外,您正在使用仿真器还是实际的电话? 有时,仿真器对滚动手势的响应方式与实际设备不同。
编辑:如果是RSSHandler的问题,我建议创建一个单独的/新的问题,适当地标记(SAX,XML解析器,RSS)。 如果您在此处发布指向该新问题的链接,我可以尝试在那儿提供帮助。 您还可以尝试首先寻找可能对SAX XML解析方法有所帮助的特定答案。 这是我最近一直在使用的一个很好的教程-http: //tutorials.jenkov.com/java-xml/sax.html
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.