|
|
|
[Android] อยากรู้วิธีเขียน ExpandableListView+SQLite ว่าเขียนอย่างไร |
|
|
|
|
|
|
|
ดึงแบบ ExpandableListView ได้แล้วหรือยังครับ ถ้าได้แล้ว ไปอ่านบทความ SQLite ได้เลยครับ
Android กับ SQLite Database
|
|
|
|
|
Date :
2013-08-02 06:26:57 |
By :
mr.win |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ก่อนหน้านี้เคยพยายามอยู่ครับ แต่ยังไม่ได้ครับ รอไว้ Phase 2 จะตามเก็บพวกนี้ให้หมดครับ
|
|
|
|
|
Date :
2013-08-02 17:29:17 |
By :
mr.win |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Code (Android-Java)
package com.example.expandablelist_db;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.ExpandableListView;
import android.widget.ExpandableListView.OnChildClickListener;
import android.widget.ExpandableListView.OnGroupCollapseListener;
public class MainActivity extends Activity {
SQLiteDatabase db;
DBHelper helper;
Cursor cursor;
ExpandableListAdapter listAdapter;
ExpandableListView expListView;
List<String> listDataHeader;
HashMap<String, List<String>> listDataChild;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
helper = new DBHelper(this);
db = helper.getWritableDatabase();
// get the listview
expListView = (ExpandableListView) findViewById(R.id.expandableListView1);
// preparing list data
prepareListData();
listAdapter = new ExpandableListAdapter(this, listDataHeader, listDataChild);
// setting list adapter
expListView.setAdapter(listAdapter);
expListView.setOnChildClickListener(new OnChildClickListener() {
@Override
public boolean onChildClick(ExpandableListView parent, View v,
int groupPosition, int childPosition, long id) {
// TODO Auto-generated method stub
Intent intent = new Intent(MainActivity.this,GMapV2.class);
intent.putExtra("ID", childPosition);
startActivity(intent);
return true;
}
});
}
private void prepareListData() {
// TODO Auto-generated method stub
listDataHeader = new ArrayList<String>();
listDataChild = new HashMap<String, List<String>>();
// Adding Header
listDataHeader.add("กระทรวงมหาดไทย");
listDataHeader.add("สำนักงานตำรวจแห่งชาติ");
listDataHeader.add("กระทรวงกลาโหม");
listDataHeader.add("กระทรวงการคลัง");
listDataHeader.add("กระทรวงการท่องเที่ยวและกีฬา");
listDataHeader.add("กระทรวงการพัฒนาสังคมและความมั่นคงของมนุษย์");
listDataHeader.add("กระทรวงเกษตรและสหกรณ์");
listDataHeader.add("กระทรวงคมนาคม");
listDataHeader.add("กระทรวงเทคโนโลยีสารสนเทศและการสื่อสาร");
listDataHeader.add("กระทรวงทรัพยากรธรรมชาติและสิ่งแวดล้อม");
listDataHeader.add("กระทรวงพาณิชย์");
listDataHeader.add("กระทรวงพลังงาน");
listDataHeader.add("กระทรวงยุติธรรม");
listDataHeader.add("กระทรวงแรงงาน");
listDataHeader.add("กระทรวงวัฒนธรรม");
listDataHeader.add("กระทรวงอุตสาหกรรม");
listDataHeader.add("สำนักงานอัยการสูงสุด");
listDataHeader.add("สำนักงานศาลยุติธรรม");
listDataHeader.add("สำนักงานพระพุทธศาสนา");
listDataHeader.add("หน่วยงานอิสระ");
listDataHeader.add("โรงเรียนอนุบาล");
listDataHeader.add("โรงเรียนประถม");
listDataHeader.add("โรงเรียนมัธยม");
listDataHeader.add("วิทยาลัยสายอาชีพ");
listDataHeader.add("โรงเรียนเทศบาล");
listDataHeader.add("ศูนย์พัฒนาเด็ก");
listDataHeader.add("มหาวิทยาลัย");
// Adding Child Data
//กระทรวงมหาดไทย str1
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงมหาดไทย'", null);
List<String> str1 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str1.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//สำนักงานตำรวจแห่งชาติ str2
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='สำนักงานตำรวจแห่งชาติ'", null);
List<String> str2 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str2.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงกลาโหม str3
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงกลาโหม'", null);
List<String> str3 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str3.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงการคลัง str4
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงการคลัง'", null);
List<String> str4 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str4.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงการท่องเที่ยวและกีฬา str5
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงการท่องเที่ยวและกีฬา'", null);
List<String> str5 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str5.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงการพัฒนาสังคมและความมั่นคงของมนุษย์ str6
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงการพัฒนาสังคมและความมั่นคงของมนุษย์'", null);
List<String> str6 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str6.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงเกษตรและสหกรณ์ str7
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงเกษตรและสหกรณ์'", null);
List<String> str7 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str7.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงคมนาคม str8
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงคมนาคม'", null);
List<String> str8 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str8.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงเทคโนโลยีสารสนเทศและการสื่อสาร str9
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงเทคโนโลยีสารสนเทศและการสื่อสาร'", null);
List<String> str9 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str9.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงทรัพยากรธรรมชาติและสิ่งแวดล้อม
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงทรัพยากรธรรมชาติและสิ่งแวดล้อม'", null);
List<String> str10 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str10.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงพาณิชย์ str11
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงพาณิชย์'", null);
List<String> str11 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str11.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงพลังงาน str12
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงพลังงาน'", null);
List<String> str12 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str12.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงยุติธรรม str13
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงยุติธรรม'", null);
List<String> str13 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str13.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงแรงงาน str14
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงแรงงาน'", null);
List<String> str14 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str14.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงวัฒนธรรม str15
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงวัฒนธรรม'", null);
List<String> str15 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str15.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//กระทรวงอุตสาหกรรม str16
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='กระทรวงอุตสาหกรรม'", null);
List<String> str16 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str16.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//สำนักงานอัยการสูงสุด str17
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='สำนักงานอัยการสูงสุด'", null);
List<String> str17 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str17.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//สำนักงานศาลยุติธรรม str18
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='สำนักงานศาลยุติธรรม'", null);
List<String> str18 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str18.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//สำนักงานพระพุทธศาสนา str19
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='สำนักงานพระพุทธศาสนา'", null);
List<String> str19 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str19.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//หน่วยงานอิสระ str20
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='หน่วยงานอิสระ'", null);
List<String> str20 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str20.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//โรงเรียนอนุบาล str21
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='โรงเรียนอนุบาล'", null);
List<String> str21 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str21.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//โรงเรียนประถม str22
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='โรงเรียนประถม'", null);
List<String> str22 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str22.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//โรงเรียนมัธยม str23
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='โรงเรียนมัธยม'", null);
List<String> str23 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str23.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//วิทยาลัยสายอาชีพ str24
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='วิทยาลัยสายอาชีพ'", null);
List<String> str24 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str24.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//โรงเรียนเทศบาล str25
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='โรงเรียนเทศบาล'", null);
List<String> str25 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str25.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//ศูนย์พัฒนาเด็ก str26
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='ศูนย์พัฒนาเด็ก'", null);
List<String> str26 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str26.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
//มหาวิทยาลัย str27
cursor = db.rawQuery("SELECT * FROM "+DBHelper.TABLE_NAME
+ " WHERE " + DBHelper.COL_CLASS + "='มหาวิทยาลัย'", null);
List<String> str27 = new ArrayList<String>();
cursor.moveToFirst();
while ( !cursor.isAfterLast() ){
str27.add(cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME)));
cursor.moveToNext();
}
listDataChild.put(listDataHeader.get(0), str1); // Header, Child data
listDataChild.put(listDataHeader.get(1), str2);
listDataChild.put(listDataHeader.get(2), str3);
listDataChild.put(listDataHeader.get(3), str4);
listDataChild.put(listDataHeader.get(4), str5);
listDataChild.put(listDataHeader.get(5), str6);
listDataChild.put(listDataHeader.get(6), str7);
listDataChild.put(listDataHeader.get(7), str8);
listDataChild.put(listDataHeader.get(8), str9);
listDataChild.put(listDataHeader.get(9), str10);
listDataChild.put(listDataHeader.get(10), str11);
listDataChild.put(listDataHeader.get(11), str12);
listDataChild.put(listDataHeader.get(12), str13);
listDataChild.put(listDataHeader.get(13), str14);
listDataChild.put(listDataHeader.get(14), str15);
listDataChild.put(listDataHeader.get(15), str16);
listDataChild.put(listDataHeader.get(16), str17);
listDataChild.put(listDataHeader.get(17), str18);
listDataChild.put(listDataHeader.get(18), str19);
listDataChild.put(listDataHeader.get(19), str20);
listDataChild.put(listDataHeader.get(20), str21);
listDataChild.put(listDataHeader.get(21), str22);
listDataChild.put(listDataHeader.get(22), str23);
listDataChild.put(listDataHeader.get(23), str24);
listDataChild.put(listDataHeader.get(24), str25);
listDataChild.put(listDataHeader.get(25), str26);
listDataChild.put(listDataHeader.get(26), str27);
}
public void onPause() {
super.onPause();
helper.close();
db.close();
}
}
|
|
|
|
|
Date :
2013-09-23 16:09:45 |
By :
tonfozil |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Code (Android-Java)
package com.example.expandablelist_db;
import java.io.InputStream;
import java.util.ArrayList;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.protocol.BasicHttpContext;
import org.apache.http.protocol.HttpContext;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.graphics.Color;
import android.os.Bundle;
import android.os.StrictMode;
import android.support.v4.app.FragmentActivity;
import android.util.Log;
import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.GoogleMap.OnMapClickListener;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.BitmapDescriptorFactory;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.MarkerOptions;
import com.google.android.gms.maps.model.PolylineOptions;
public class GMapV2 extends FragmentActivity {
Cursor cursor;
SQLiteDatabase db;
DBHelper helper;
GoogleMap map;
LatLng fromMarkerPosition = new LatLng(0,0);
LatLng toMarkerPosition = new LatLng(0,0);
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_map);
if (android.os.Build.VERSION.SDK_INT > 9) {
StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder()
.permitAll().build();
StrictMode.setThreadPolicy(policy);
}
map = ((SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map)).getMap();
map.setMyLocationEnabled(true);
helper = new DBHelper(this);
db = helper.getWritableDatabase();
final int ID = getIntent().getIntExtra("ID", -1) +1;
Log.i("Check", String.valueOf(ID));
cursor = db.rawQuery("SELECT * FROM tbOfficial WHERE "+
DBHelper.COL_ID + " ='" + ID + "'", null);
cursor.moveToFirst();
double lat_db = cursor.getDouble(cursor.getColumnIndex(DBHelper.COL_LAT));
double lng_db = cursor.getDouble(cursor.getColumnIndex(DBHelper.COL_LNG));
String M_Name = cursor.getString(cursor.getColumnIndex(DBHelper.COL_NAME));
LatLng toPosition = new LatLng(lat_db, lng_db);
map.addMarker(new MarkerOptions().position(toPosition).title(M_Name));
map.animateCamera(CameraUpdateFactory.newLatLngZoom(toPosition, 16));
map.setOnMapClickListener(new OnMapClickListener() {
public void onMapClick(LatLng arg0) {
final LatLng coordinate = arg0;
AlertDialog.Builder builder = new AlertDialog.Builder(GMapV2.this);
builder.setTitle("Getdirection")
.setItems(new String[]{ "ต้นทาง (A)", "ปลายทาง (B)" }, new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int position) {
if(position == 0)
fromMarkerPosition = coordinate;
else if(position == 1)
toMarkerPosition = coordinate;
DrowingformMap();
}
});
builder.show();
}
});
DrowingformMap();
}
public void DrowingformMap() {
map.addMarker(new MarkerOptions().position(fromMarkerPosition)
.icon(BitmapDescriptorFactory.fromAsset("A.png"))
.title("A"));
map.addMarker(new MarkerOptions().position(toMarkerPosition)
.icon(BitmapDescriptorFactory.fromAsset("B.png"))
.title("B"));
ArrayList<LatLng> directionPoint = getDirections(fromMarkerPosition, toMarkerPosition);
PolylineOptions rectLine = new PolylineOptions().width(4).color(Color.RED);
for(int i = 0 ; i < directionPoint.size() ; i++) {
rectLine.add(directionPoint.get(i));
}
map.addPolyline(rectLine);
}
public static ArrayList<LatLng> getDirections(LatLng latlng1, LatLng latlng2) {
String url = "http://maps.googleapis.com/maps/api/directions/xml?"
+ "origin=" + latlng1.latitude + "," + latlng1.longitude
+ "&destination=" + latlng2.latitude + "," + latlng2.longitude
+ "&sensor=false&units=metric&mode=driving";
String tag[] = { "step" };
ArrayList<LatLng> listGeopoints = new ArrayList<LatLng>();
HttpResponse response = null;
try {
HttpClient httpClient = new DefaultHttpClient();
HttpContext localContext = new BasicHttpContext();
HttpPost httpPost = new HttpPost(url);
response = httpClient.execute(httpPost, localContext);
InputStream in = response.getEntity().getContent();
DocumentBuilder builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
Document doc = builder.parse(in);
if (doc != null) {
NodeList nl1, nl2, nl3;
nl1 = doc.getElementsByTagName(tag[0]);
if (nl1.getLength() > 0) {
for (int i = 0; i < nl1.getLength(); i++) {
Node node1 = nl1.item(i);
nl2 = node1.getChildNodes();
Node locationNode = nl2.item(getNodeIndex(nl2, "start_location"));
nl3 = locationNode.getChildNodes();
Node latNode = nl3.item(getNodeIndex(nl3, "lat"));
double lat = Double.parseDouble(latNode.getTextContent());
Node lngNode = nl3.item(getNodeIndex(nl3, "lng"));
double lng = Double.parseDouble(lngNode.getTextContent());
listGeopoints.add(new LatLng(lat, lng));
locationNode = nl2.item(getNodeIndex(nl2, "polyline"));
nl3 = locationNode.getChildNodes();
latNode = nl3.item(getNodeIndex(nl3, "points"));
ArrayList<LatLng> arr = decodePoly(latNode.getTextContent());
for(int j = 0 ; j < arr.size() ; j++) {
listGeopoints.add(new LatLng(arr.get(j).latitude, arr.get(j).longitude));
}
locationNode = nl2.item(getNodeIndex(nl2, "end_location"));
nl3 = locationNode.getChildNodes();
latNode = nl3.item(getNodeIndex(nl3, "lat"));
lat = Double.parseDouble(latNode.getTextContent());
lngNode = nl3.item(getNodeIndex(nl3, "lng"));
lng = Double.parseDouble(lngNode.getTextContent());
listGeopoints.add(new LatLng(lat, lng));
}
}
}
} catch (Exception e) {
e.printStackTrace();
}
return listGeopoints;
}
private static int getNodeIndex(NodeList nl, String nodename) {
for(int i = 0 ; i < nl.getLength() ; i++) {
if(nl.item(i).getNodeName().equals(nodename))
return i;
}
return -1;
}
public static ArrayList<LatLng> decodePoly(String encoded) {
ArrayList<LatLng> poly = new ArrayList<LatLng>();
int index = 0, len = encoded.length();
int lat = 0, lng = 0;
while (index < len) {
int b, shift = 0, result = 0;
do {
b = encoded.charAt(index++) - 63;
result |= (b & 0x1f) << shift;
shift += 5;
} while (b >= 0x20);
int dlat = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1));
lat += dlat;
shift = 0;
result = 0;
do {
b = encoded.charAt(index++) - 63;
result |= (b & 0x1f) << shift;
shift += 5;
} while (b >= 0x20);
int dlng = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1));
lng += dlng;
LatLng position = new LatLng((double) lat / 1E5, (double) lng / 1E5);
poly.add(position);
}
return poly;
}
}
|
|
|
|
|
Date :
2013-09-23 16:10:25 |
By :
tonfozil |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
คือตอนนี้มีกลุ่มอยู่ทั้ง 27 กลุ่ม
ตอนแสดงหน้าแผนที่ ข้อมูลแสดงแค่กลุ่มแรก
เลือกกลุ่มอื่น ข้อมูลมันก็แสดงที่กลุ่มแรก มันเป็นอะไรหรอครับ ผมไม่เข้าใจเลย ช่วยอธิบาหน่อย
|
|
|
|
|
Date :
2013-09-23 16:15:55 |
By :
tonfozil |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ได้แล้วเหรอครับ
|
|
|
|
|
Date :
2013-09-23 16:16:37 |
By :
mr.win |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ครับ แต่ติดอยู่ที่ เลือกข้อมูลที่อื่น มันจะแสดงแต่ข้อมูลของกลุ่มแรก อะ ไม่รู้แก้ยังไง ช่วยอธิบายหน่อยครับ T^T
|
|
|
|
|
Date :
2013-09-23 16:19:40 |
By :
tonfozil |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ลองใส่adapter แบบนี้สิครับ ผมก้อก๊อปมาจาก http://tutorial.function.in.th/android/example-expandablelistview แล้วเอามาแปลงๆนิดหน่อยให้รับ head เป็น ArrayList<String> แล้วก้อรับ child เป็น HashMap<String, List<String>>
Code
protected class MyExpadableAdapter extends BaseExpandableListAdapter
{
private ArrayList<String> group = null;
private HashMap<String, List<String>> children = null;
public MyExpadableAdapter (ArrayList<String> group, HashMap<String, List<String>> children )
{
this.group = group;
this.children = children;
}
public Object getChild ( int groupPosition, int childPosition )
{
return this.children.get(group.get(groupPosition)).get(childPosition).toString();
}
public long getChildId ( int groupPosition, int childPosition )
{
return childPosition;
}
public View getChildView ( int groupPosition, int childPosition, boolean isLastChild, View convertView, ViewGroup parent )
{
AbsListView.LayoutParams layoutParams = new AbsListView.LayoutParams ( ViewGroup.LayoutParams.FILL_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT );
TextView textView = new TextView ( context );
textView.setLayoutParams ( layoutParams );
textView.setPadding ( 5, 5, 5, 5 );
textView.setText ( this.children.get(group.get(groupPosition)).get(childPosition).toString());
return textView;
}
public int getChildrenCount ( int groupPosition )
{
return this.children.get(group.get(groupPosition)).size();
}
public Object getGroup ( int groupPosition )
{
return this.group.get(groupPosition);
}
public int getGroupCount ( )
{
return this.group.size();
}
public long getGroupId ( int groupPosition )
{
return groupPosition;
}
public View getGroupView ( int groupPosition, boolean isExpanded, View convertView, ViewGroup parent )
{
AbsListView.LayoutParams layoutParams = new AbsListView.LayoutParams ( ViewGroup.LayoutParams.FILL_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT );
TextView textView = new TextView ( context );
textView.setLayoutParams ( layoutParams );
textView.setGravity ( Gravity.CENTER );
textView.setPadding ( 18, 18, 18, 18 );
textView.setText ( this.group.get(groupPosition));
return textView;
}
public boolean hasStableIds ( )
{
return true;
}
public boolean isChildSelectable ( int groupPosition, int childPosition )
{
return true;
}
}
|
|
|
|
|
Date :
2014-02-15 05:03:40 |
By :
theletter |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Load balance : Server 02
|