1

私はこれを見過ぎているか、これを考え過ぎていることを知っていますが、ユーザーがクリックしたときに RSS フィードのリンクを起動する方法を理解できないようです。私はDOMパーサーを使用してxmlファイルをリストビューに解析し、xmlファイルからすべての情報を取得しています。私が抱えている問題は、私が持っているカスタム WebActivity に解析して、私が持っている webview クライアントもロードする必要があることです。ここに私が取り組んでいるコードがあります。

主な活動

 public class CustomizedListView extends Activity {
// All static variables
static final String URL = "http://treymorgan.net/feed";
// XML node keys
static final String KEY_ITEM = "item"; // parent node 
static final String KEY_ID = "id";
static final String KEY_TITLE = "title";
static final String KEY_PUB_DATE = "pubDate";
static final String KEY_LINK = "guid";

ListView list;
LazyAdapter adapter;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);


    ArrayList<HashMap<String, String>> songsList = new ArrayList<HashMap<String, String>>();

    XMLParser parser = new XMLParser();
    String xml = parser.getXmlFromUrl(URL); // getting XML from URL
    Document doc = parser.getDomElement(xml); // getting DOM element

    NodeList nl = doc.getElementsByTagName(KEY_ITEM);
    // looping through all song nodes <song>
    for (int i = 0; i < nl.getLength(); i++) {
        // creating new HashMap
        HashMap<String, String> map = new HashMap<String, String>();
        Element e = (Element) nl.item(i);
        // adding each child node to HashMap key => value
        map.put(KEY_ID, parser.getValue(e, KEY_ID));
        map.put(KEY_TITLE, parser.getValue(e, KEY_TITLE));
        map.put(KEY_PUB_DATE, parser.getValue(e, KEY_PUB_DATE));
        map.put(KEY_LINK, parser.getValue(e, KEY_LINK));

        // adding HashList to ArrayList
        songsList.add(map);
    }


    list=(ListView)findViewById(R.id.list);

    // Getting adapter by passing xml data ArrayList
    adapter=new LazyAdapter(this, songsList);        
    list.setAdapter(adapter);


    // Click event for single list row
    list.setOnItemClickListener(new OnItemClickListener() {

編集:これは私が問題を抱えているコードのセクションです...デバイスのネイティブブラウザーではなくアプリで表示できるように、rssフィードからwebviewアクティビティにURLを送信するonItemClickメソッド

        @Override
        public void onItemClick(AdapterView<?> parent, View view,
                int position, long id) {
            Intent intent = new Intent(CustomizedListView.this, WebviewActivity.class);  
            Bundle b = new Bundle();
            intent.putExtra("KEY_LINK", b);
            startActivity(intent); 



             }

    });
}   
 }

これが私のWebviewアクティビティです

 public class WebviewActivity extends Activity{
  private WebView webview;

  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.webview);

    Bundle b = getIntent().getExtras(); 
    String KEY_LINK = b.getString("KEY_LINK");

    webview = (WebView) findViewById(R.id.webView1);
    webview.setWebViewClient(new MyWebViewClient(this));
    webview.getSettings().setAppCacheEnabled(false);
    webview.getSettings().setBuiltInZoomControls(true);
    webview.setInitialScale(1);
    webview.loadUrl(KEY_LINK);



  }


       }

基本的に、私がやりたいことは、KEY_GUID を WebviewActivity に文字列化することです。あるアクティビティから別のアクティビティに文字列を受け取る方法がわかりません。助けてくれてありがとう

編集: OK、私はこれにしばらく取り組んでおり、この問題に関連する使用中のコードを更新しました。これでエラーはなくなり、アイテムをクリックすると WebviewActivity が開きますが、Web サイトが読み込まれず、Webview クライアントも接続されません。誰でもこれを理解するのを手伝ってもらえますか?

編集:次のようなコードをロードすると:

 @Override
        public void onItemClick(AdapterView<?> parent, View view,
                int position, long id) {

            Intent intent = new Intent(CustomizedListView.this,    WebviewActivity.class);  
            Bundle b = new Bundle();
            intent.putExtra("b", "http://www.google.com" );
            startActivity(intent); 

webview アクティビティを開き、Google を正常に読み込みます。おそらく、私が今抱えている問題は、DOM パーサーから必要なリンクを取得する方法です。誰にもアイデアはありますか?

4

3 に答える 3

0

あなたの通話活動では:

Intent i = new Intent(this, WebActivity.class);
i.putExtra(MY_KEY, "http://http://stackoverflow.com");
startActivity(i);

あなたの受信活動で:

protected void onStart() {
  super.onStart();
  String myUrl = getExtras().getString(MY_KEY);
  webView.loadUrl(myUrl);
}

編集:

アダプターにHashMapsが含まれていると仮定します(XMLの解析方法について私が見たものから)

@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
  HashMap<String, String> selectedSong = (HashMap<String, String>) parent.getItemAtPosition(position);

  Intent intent = new Intent(CustomizedListView.this, WebviewActivity.class);  
  intent.putExtra("KEY_LINK", selectedSong.get(KEY_LINK));
  startActivity(intent); 
}
于 2012-10-04T22:45:16.077 に答える
0

わかりました、これが私が尋ねた私の質問に対する答えです。これは私にとってはうまく機能し、私が望んでいたとおりに機能しました。これがその作業コードです

 public class CustomizedListView extends Activity {
// All static variables
static final String URL = "http://treymorgan.net/feed";
// XML node keys
static final String KEY_ITEM = "item"; // parent node 
static final String KEY_ID = "id";
static final String KEY_TITLE = "title";
static final String KEY_PUB_DATE = "pubDate";
static final String KEY_LINK = "link";

ListView list;
LazyAdapter adapter;

ArrayList<HashMap<String, String>> songsList = new ArrayList<HashMap<String, String>>();

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);


    final ArrayList<HashMap<String, String>> songsList = new ArrayList<HashMap<String, String>>();

    XMLParser parser = new XMLParser();
    String xml = parser.getXmlFromUrl(URL); // getting XML from URL
    Document doc = parser.getDomElement(xml); // getting DOM element

    NodeList nl = doc.getElementsByTagName(KEY_ITEM);
    // looping through all song nodes <song>
    for (int i = 0; i < nl.getLength(); i++) {
        // creating new HashMap
        HashMap<String, String> map = new HashMap<String, String>();
        Element e = (Element) nl.item(i);
        // adding each child node to HashMap key => value
        map.put(KEY_ID, parser.getValue(e, KEY_ITEM));
        map.put(KEY_TITLE, parser.getValue(e, KEY_TITLE));
        map.put(KEY_PUB_DATE, parser.getValue(e, KEY_PUB_DATE));
        map.put(KEY_LINK, parser.getValue(e, KEY_LINK));

        // adding HashList to ArrayList
        songsList.add(map);
    }


    list=(ListView)findViewById(R.id.list);

    // Getting adapter by passing xml data ArrayList
    adapter=new LazyAdapter(this, songsList);        
    list.setAdapter(adapter);


    // Click event for single list row
    list.setOnItemClickListener(new OnItemClickListener() {

        @Override
        public void onItemClick(AdapterView<?> parent, View view,
                int position, long id) {

            Intent intent = new Intent(CustomizedListView.this, WebviewActivity.class);  
            new Bundle();
            intent.putExtra( "b", songsList.get(position).get(KEY_LINK));
            startActivity(intent); 



             }

    });
}   
 }
于 2012-10-19T04:21:32.570 に答える
0

あるアクティビティから別のアクティビティへのパス文字列の場合

最初のアクティビティ:

Intent indisplay = new Intent(FirstClass.this,SecondClass.class);
indisplay.putExtra("link",your link here);
startActivity(indisplay);

2 番目のアクティビティ:

 Intent indispaly = getIntent();
 String url = indispaly.getStringExtra("link");
    // your link from previous activity is stored into the url

そして、webviewに表示するには、次のようにします。

    protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);

    this.getWindow().requestFeature(Window.FEATURE_PROGRESS);
    setContentView(R.layout.newsdisplay);
    getWindow().setFeatureInt( Window.FEATURE_PROGRESS, Window.PROGRESS_VISIBILITY_ON); 


    Intent indispaly = getIntent();
    String url = indispaly.getStringExtra("link");

    newswebview = (WebView) findViewById(R.id.news_webView);
    newswebview.setWebViewClient(new WebViewClient());

    WebSettings webSettings = newswebview.getSettings();
    webSettings.setJavaScriptEnabled(true);

    newswebview.getSettings().setSupportZoom(true);       //Zoom Control on web (You don't need this 
     //if ROM supports Multi-Touch      
    newswebview.getSettings().setBuiltInZoomControls(true); //Enable Multitouch if supported by ROM


    newswebview.loadUrl(url);


    final Activity MyActivity = this;


newswebview.setWebChromeClient(new WebChromeClient() {
    public void onProgressChanged(WebView view, int progress) 
       {

        //Make the bar disappear after URL is loaded, and changes string to Loading...
        MyActivity.setTitle("  Loading...");
        MyActivity.setProgress(progress * 100); //Make the bar disappear after URL is loaded

        // Return the app name after finish loading
           if(progress == 100){

               MyActivity.setTitle(R.string.app_name);

           }


    }
});

}

 @Override  
    public boolean onKeyDown(int keyCode, KeyEvent event)   
    {  
        if ((keyCode == KeyEvent.KEYCODE_BACK) && newswebview.canGoBack()) {  
            newswebview.goBack();  
            return true;  
        }  
        return super.onKeyDown(keyCode, event);  
    }   
于 2012-10-05T04:06:17.753 に答える