Android TextView会在一段后切断

时间:2012-12-03 19:28:18

标签: java android textview

我正在为学校报纸创建一个应用程序,并在尝试显示完整文章时遇到问题。目前,我有一个从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());

    }
}

此时我已经做了很多搜索并且没有找到解决方案,我不确定我的代码的哪一部分可能导致问题。我有一个链接可以在这里下载我的完整项目,如果有人可以看看并找到问题。

如果有人知道从哪里开始寻找,我会提出这段代码。

https://lh.rs/zbdYev99O1G5

1 个答案:

答案 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