Android Touch開發搜尋應用

來源:互聯網
上載者:User

一 設計相關介面

我們的介面很簡單,只是一個文本輸入框,一個“Search”的檢索按鈕,以及展示檢索結果的內容地區。下面是相關代碼:

java代碼:

 
  1. Ext.setup({   
  2. onReady: function() {   
  3. var topToolbar = new Ext.Toolbar({   
  4. dock : 'top',   
  5. ui: 'dark',   
  6. title: 'Sencha Twitter Search'   
  7. });   
  8. var tpl = new Ext.XTemplate(   
  9. '<div id="tweet_container">',   
  10. '<tpl for=".">',   
  11. '<div class="tweet_data">',   
  12. '<div class="tweet_avatar">',   
  13. '<img width="30" height="30" src="{profile_image_url}"/>',   
  14. '</div>',   
  15. '<div class="tweet_content">',   
  16. '<a class="user" href="http://twitter.com/{from_user}">{from_user}</a> ',   
  17. '{text}',   
  18. '</div>',   
  19. '<div class="clear"></div>',   
  20. '</div>',   
  21. '</tpl>',   
  22. '</div>'   
  23. );   
  24. var resultPanel = new Ext.Panel({   
  25. layout: 'fit',   
  26. style: 'padding-bottom: 10px;',   
  27. tpl: tpl   
  28. });   
  29. var searchPanel = new Ext.Panel({   
  30. padding: 10,   
  31. layout: {   
  32. type: 'hbox',   
  33. align: 'stretch'   
  34. },   
  35. items: [{   
  36. flex: 4,   
  37. xtype: 'textfield',   
  38. style: 'margin-right: 10px;',   
  39. id: 'textquery'   
  40. },{   
  41. flex: 2,   
  42. xtype: 'button',   
  43. text: 'Search',   
  44. handler: function() {   
  45. var query = Ext.getCmp("textquery").getValue();   
  46. Ext.Ajax.request({   
  47. url: 'index.php?act=search&q='+query,   
  48. success: function(e) {   
  49. var obj = Ext.util.JSON.decode(e.responseText);   
  50. var msg = obj.results;   
  51. var html = tpl.apply(msg);   
  52. resultPanel.update(html);   
  53. }   
  54. });   
  55. }   
  56. }]   
  57. });   
  58. var myPanel = new Ext.Panel({   
  59. dockedItems: [topToolbar],   
  60. items: [searchPanel, resultPanel],   
  61. scroll: 'vertical',   
  62. style: 'background: #DDEEF6;',   
  63. fullscreen : true   
  64. });   
  65. }   
  66. });  

在這裡,首先設定了topToolbar標題列,標題列的內容為Sencha Twitter Search。接著使用EXT的Ext.XTemplate設計了一個模版,模版中的內容是按照twitter中的格式設計的,即發微博人的相片、使用者名稱以及所發的言論。而resultPanel中是顯示結果的面板,searchPanel則是輸入檢索條件的面板,其中請注意handler方法,使用query變數獲得了使用者的輸入檢索詞,之後使用get的方法,使用ajax的方式發送到index.php去處理本例子中把EXTJS代碼和PHP代碼寫在同一個PHP檔案中了,當然也可以分開來編寫,那麼的話就使用POST方法了),同時,在success的回呼函數中,對AJAX調用返回的結果進行處理,

其中,使用var obj = Ext.util.JSON.decode(e.responseText),對檢索的結果JSON格式進行解碼,將返回的JSON格式字串轉變為JSON格式的對象,並且用tpl.apply(msg),將解析後的結果應用到之前的模版tpl中,最後要記得使用resultPanel.update(html);更新一下該地區。

二  PHP獲得twitter內容的代碼

在同一個index.php檔案中,通過使用get的方法,發送查詢請求關鍵字到twitter公開的API進行查詢,代碼如下:

java代碼:

 
  1. if (isset($_GET["act"]) && $_GET["act"] == "search") {   
  2. $url = 'http://search.twitter.com/search.json?q='.$_GET["q"];   
  3. $content = file_get_contents($url);   
  4. $array = json_decode($content);   
  5. $data = array();   
  6. foreach ($array->results as $var => $value) {   
  7. $pattern = '/\b(https?:\/\/[-A-Z0-9+&@#\/%?=~_|$!:,.;]*[A-Z0-9+&@#\/%=~_|$])/i';   
  8. preg_match_all($pattern, $value->text, $regs);   
  9. $loop = count($regs[0]);   
  10. for ($i = 0; $i < $loop; $i++) {   
  11. $value->text = str_replace($regs[0][$i], '<a class="outlink" href="'.$regs[0][$i].'">'.$regs[0][$i].'</a>', $value->text);   
  12. }   
  13. $data[] = array(   
  14. "profile_image_url" => $value->profile_image_url,   
  15. "from_user" => $value->from_user,   
  16. "text" => $value->text   
  17. );   
  18. }   
  19. $out = array(   
  20. "success" => true,   
  21. "results" => $data   
  22. );   
  23. echo json_encode($out);   
  24. exit;   
  25. }  

Android環境變數的設定

Android系統重要檔案類型詳解

Android開發之旅:Android架構

Android應用程式開發環境的搭建

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.