ArrayList<SearchEngineInfo> searchEngineInfos = new ArrayList<SearchEngineInfo>();
Resources res = context.getResources();
String[] searchEngines = res.getStringArray(R.array.search_engines);
for (int i = 0; i < searchEngines.length; i++) {
String name = searchEngines[i];
SearchEngineInfo info = new SearchEngineInfo(context, name);
searchEngineInfos.add(info);
}
return searchEngineInfos;
}
看到R.array.search_engines我們就找到配置搜索引擎的數據源頭了,在res/values/search_engines.xml中。 定義如下:
<!--
****
**** THIS FILE WAS GENERATED BY tools/get_search_engines.py
****
Each value in the string-array is the name of a value in all_search_engines.xml
-->
<resources xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
<string-array name="search_engines" translatable="false">
<item>google</item>
<item>baidu</item>
<item>Yahoo</item>
</string-array>
</resources>
繼續看,註釋中已經提醒我們,這裏的item只是一個引用,真正的定義在all_search_engines.xml中。這樣也是方便不同區域語言下的搜索引擎管理。集中到一個文件中定義,避免不必要的重複數據,也就是說瀏覽器所支持的所有搜索引擎都在這裏,我們要添加一個支持的搜索引擎也要在這裏添加。
以Yahoo_uk爲例
<string-array name="yahoo_uk" translatable="false"> //調用引擎的id
<item>Yahoo! UK & Ireland</item> //顯示名稱
<item>uk.yahoo.com</item> //地址
<item>http://uk.search.yahoo.com/favicon.ico</item> //網絡圖標顯示
<item>http://uk.search.yahoo.com/search?ei={inputEncoding}&fr=crmas&p={searchTerms}</item>
<item>UTF-8</item> //編碼格式
<item>http://uk-sayt.ff.search.yahoo.com/gossip-uk-sayt?output=fxjson&command={searchTerms}</item>
</string-array>
每個searchEngine都定義了6個<item>從上到下依次表示顯示標籤,關鍵字,搜索圖標,搜索引擎地址,編碼方式,搜索提示地址。 這些值因區域語言不同而不同。所以對不同的區域可能需要定義不同的搜索引擎。我們這裏需要添加一個支持中國地區的xxx定義就可以了。
<string-array name="xxxx" translatable="true">
<item>@string/xxxx_str</item>
<item>xxx.xxx.com</item>
<item>http://xxx.xxx.com/favicon.ico</item>
<item>http:// xxx.xxx.com/search?ei={inputEncoding}&fr=crmas&p={searchTerms}</item>
<item>GB2312</item>
<item></item>
</string-array>