Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 108,221

HOME > Mobile > Mobile Forum > ขอโค๊ด คำสั่ง search โดยแสดงเป็น listview ข้อมูลจาก database โดยใช้ JSON



 

ขอโค๊ด คำสั่ง search โดยแสดงเป็น listview ข้อมูลจาก database โดยใช้ JSON

 



Topic : 090528

Guest




ขอโค๊ด คำสั่ง search โดยแสดงเป็น listview ข้อมูลจาก database โดยใช้ JSON

code

Code (Android-Java)
	private static final String TAG_SUCCESS 	= "success";
	private static final String TAG_ABSENT		= "absent";
	//output
	private static final String TAG_EMPCODE 		= "empcode";
	private static final String TAG_FNAME    		= "fname";
	private static final String TAG_LNAME			= "lname";
	private static final String TAG_DEP_NAME		= "dep_name";
	private static final String TAG_BRANCH		= "branch";
	private static final String TAG_IMG_URL		= "img_url";
	
	String img_url,empcode,fname,lname,dep_name,branch;
	String action = "employee_list";
	EditText inputSearch;
	int textlength=0;
	Button btn_search;

	JSONParser jParser = new JSONParser();
	ArrayList<HashMap<String , String >> data;
	ArrayList<HashMap<String , String >> searchResults;
	ArrayList<HashMap<String , String>> search;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.layout_aex_employee);
	
		 try{  
					 List<NameValuePair> params = new ArrayList<NameValuePair>();
					 params.add(new BasicNameValuePair("action",action));
				   	 // getting employee's details by making HTTP request
		             // Note that employee's details URL will use GET request
					 Log.i("params",params.toString());
		             JSONObject json = jParser.makeHttpRequest(url, "GET" ,params);
		             Log.d("json",json.toString());
		             
		             
		        	int success = json.getInt(TAG_SUCCESS);
		           	if (success == 1) {
		     
		           		JSONArray empObj = json.getJSONArray(TAG_ABSENT); // JSON Array
		           		final ListView list_employee=(ListView)findViewById(R.id.list_employee);
		           		data = new ArrayList<HashMap<String,String>>();
			           		for(int i=0;i<empObj.length();i++){
			           			JSONObject c= empObj.getJSONObject(i);
			           			empcode		=c.getString(TAG_EMPCODE);
			           			fname		=c.getString(TAG_FNAME);
			           			lname		=c.getString(TAG_LNAME);
			           			dep_name	=c.getString(TAG_DEP_NAME);
			           			branch		=c.getString(TAG_BRANCH);
			           			img_url		=c.getString(TAG_IMG_URL);
			           			
			           			HashMap<String , String >map=new HashMap<String, String>();
			           			map.put(TAG_EMPCODE, empcode);
			           			map.put(TAG_FNAME, fname);
			           			map.put(TAG_LNAME, lname);
			           			map.put(TAG_DEP_NAME, dep_name);
			           			map.put(TAG_BRANCH, branch);
			           			map.put(TAG_IMG_URL, img_url);
			           			data.add(map); 
			           		}
			           		
			           		list_employee.setAdapter(new AbsentAdapter(this));
			           		list_employee.setOnItemClickListener(new OnItemClickListener() {

								@Override
								public void onItemClick(AdapterView<?> arg0,
										View view, int position, long id) {
									// TODO Auto-generated method stub
									TextView empcode =(TextView)view.findViewById(R.id.textView1);
									empcode.setText(data.get(position).get(TAG_EMPCODE));
									String emp=empcode.getText().toString();
									Intent intent = new Intent(getApplicationContext(),aex_employee_personal.class);
									intent.putExtra("empcode", emp);
									startActivity(intent);
								}
							});
			           		
			           		searchResults=new ArrayList<HashMap<String,String>>(data);
			           		
			           		inputSearch=(EditText)findViewById(R.id.edit_search);
			           		InputMethodManager imm =(InputMethodManager)getSystemService(Context.INPUT_METHOD_SERVICE);
			           		imm.hideSoftInputFromWindow(inputSearch.getWindowToken(), 0);
			           		
			           		inputSearch.addTextChangedListener(new TextWatcher() {
								@Override
								public void onTextChanged(CharSequence s, int start, int before, int count) {
									// TODO Auto-generated method stub
									
									String searchString=inputSearch.getText().toString();
									textlength=searchString.length();
									searchResults.clear();
									for(int i=0;i<data.size();i++){
										String playerName=data.get(i).get(TAG_EMPCODE).toString();
										if(textlength<=playerName.length()){
											if(searchString.equalsIgnoreCase(playerName.substring(0,textlength))){
												Log.i("searchResults",searchResults.toString());
												searchResults.add(data.get(i));
												
												
												String[] from ={"TextView","TextView","TextView","TextView","TextView"};
												int[] to={R.id.textView1,R.id.textView2,R.id.textView3,R.id.textView4,R.id.textView5};
												SimpleAdapter sAdap = new SimpleAdapter(aex_employee.this,searchResults,
														R.layout.layout_item_employee,from,to);
												list_employee.setAdapter(sAdap);
											}
										}
									}
				}
							
								@Override
								public void beforeTextChanged(CharSequence s, int start, int count,
										int after) {
									// TODO Auto-generated method stub
								}
								@Override
								public void afterTextChanged(Editable s) {
									// TODO Auto-generated method stub
								}
							});
		           	} else {
		                Toast.makeText(getApplicationContext(), "ไม่พบข้อมูล", Toast.LENGTH_SHORT).show();
		            }
		        } catch (JSONException e) {
		            e.printStackTrace();
		            Toast.makeText(getApplicationContext(), e.toString(), Toast.LENGTH_SHORT).show();
		        } 
	}
		class AbsentAdapter extends BaseAdapter{
			
			private Context context;
			public AbsentAdapter(Context c){
				context=c;
			}
			
			public AbsentAdapter(TextWatcher textWatcher){
			
			}

			@Override
			public int getCount() {
				// TODO Auto-generated method stub
				return data.size();
			}

			@Override
			public Object getItem(int position) {
				// TODO Auto-generated method stub
				return position;
			}

			@Override
			public long getItemId(int position) {
				// TODO Auto-generated method stub
				return position;
			}

			@Override
			public View getView(int position, View view, ViewGroup parent) {
				// TODO Auto-generated method stub
				
				LayoutInflater infater =(LayoutInflater) context.getSystemService(context.LAYOUT_INFLATER_SERVICE);
				if(view == null){
				
					view = infater.inflate(R.layout.layout_item_employee,null);
				}
				
				//empcode
				TextView txt_empcode =(TextView)view.findViewById(R.id.textView1);
				txt_empcode.setText(data.get(position).get(TAG_EMPCODE));
				
				//fname
				TextView txt_fname =(TextView)view.findViewById(R.id.textView2);
				txt_fname.setText(data.get(position).get(TAG_FNAME));
				
				//lname
				TextView txt_lname =(TextView)view.findViewById(R.id.textView3);
				txt_lname.setText(data.get(position).get(TAG_LNAME));
				
				//dep_name
				TextView txt_dep_name =(TextView)view.findViewById(R.id.textView4);
				txt_dep_name.setText(data.get(position).get(TAG_DEP_NAME));
				
				//branch
				TextView txt_branch =(TextView)view.findViewById(R.id.textView5);
				txt_branch.setText(data.get(position).get(TAG_BRANCH));
				
				//img_url
				ImageView img =(ImageView)view.findViewById(R.id.imageView1);
				URL url;
				try {
					url = new URL(data.get(position).get(TAG_IMG_URL));
					img.getLayoutParams().height =90;
					img.getLayoutParams().width= 90;
					img.setImageBitmap(BitmapFactory.decodeStream(url.openStream()));
				} catch (MalformedURLException e) {
					e.printStackTrace();
				} catch (IOException e) {
					e.printStackTrace();
				}

				return view;
			}			
		}
		
}




Tag : Mobile, Android, JAVA, Windows







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2013-02-08 11:39:01 By : v_rong View : 1946 Reply : 2
 

 

No. 1



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook

ตัวนี้เลยครับ



Android ProgressBar/ProgressDialog Search Display result Data from Web Server







แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-02-08 12:51:49 By : mr.win
 


 

No. 2



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook



Go to : Android and Web Server ของ PHP กับ MySQL แสดงบน ListView ในรูปแบบของ JSON
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-02-10 07:50:41 By : mr.win
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : ขอโค๊ด คำสั่ง search โดยแสดงเป็น listview ข้อมูลจาก database โดยใช้ JSON
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: Voake, Comcube, รับทำเว็บไซต์ รับเขียนโปรแกรม , รับทำบัญชี , โรงงานผลิตครีม , สำนักงานบัญชี , รับจดทะเบียนบริษัท

Load balance : Server 03
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2020 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 , 08-9968-0655 อัตราราคา คลิกที่นี่