In this blog, what we are trying to achieve is the search functionality.
There is a search box on the top. When user tries to enter some text, a restful API will be called on the server with this text as the search text. The returned data which is in JSON format will be parsed and pushed into an ArrayList. Then this ArrayList will be used to populate the ListView of the results.
Once the results are displayed, the user can scroll up or down and there would be a provision for user to add this element to cart as well.
The final result looks like this
The complete video on how to achieve this has been explained in the below video.
The source code is as follows
Update the fragment_search.xml with the following code.
Please the following file listtwo_searchresults.xml in the res/layout folder
Place the barcode icon in the res/drawable-hdpi folder. Change the name of the file as barcode.jpg
Place the cart icon in the res/drawable-hdpi folder. Change the name of the file as cart_low.jpg
Update the code for Search.java
There is a search box on the top. When user tries to enter some text, a restful API will be called on the server with this text as the search text. The returned data which is in JSON format will be parsed and pushed into an ArrayList. Then this ArrayList will be used to populate the ListView of the results.
Once the results are displayed, the user can scroll up or down and there would be a provision for user to add this element to cart as well.
The final result looks like this
The complete video on how to achieve this has been explained in the below video.
The source code is as follows
Update the fragment_search.xml with the following code.
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:background="#E6E6E6"> <View android:id="@+id/view1" android:layout_width="match_parent" android:layout_height="45dp" android:layout_alignParentTop="true" android:background="#FFFFFF" android:layout_marginTop="5dp" android:layout_marginLeft="5dp" android:layout_marginRight="5dp"/> <SearchView android:id="@+id/searchView1" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentTop="true" android:layout_toLeftOf="@+id/imageButton1" android:layout_marginTop="3dp" android:layout_marginLeft="10dp" android:layout_marginRight="10dp"> </SearchView> <ImageButton android:id="@+id/imageButton1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentTop="true" android:layout_marginRight="0dp" android:layout_marginTop="3dp" android:layout_toLeftOf="@+id/imageButton2" android:src="@android:drawable/ic_btn_speak_now" /> <ImageButton android:id="@+id/imageButton2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentRight="true" android:layout_alignParentTop="true" android:layout_marginRight="5dp" android:layout_marginTop="3dp" android:src="@drawable/barcode"/> <ListView android:id="@+id/listview_search" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_centerHorizontal="true" android:layout_below="@+id/imageButton2" android:layout_marginTop="25dp" android:dividerHeight="5dp" android:divider="#E6E6E6"/> </RelativeLayout>
Please the following file listtwo_searchresults.xml in the res/layout folder
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:background="#FFFFFF" android:layout_marginLeft="5dp" android:layout_marginRight="5dp" android:layout_height="match_parent"> <ImageView android:id="@+id/productImage" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_marginTop="5dp" android:layout_marginLeft = "5dp" android:layout_alignParentTop="True" android:src="@drawable/ic_launcher" /> <TextView android:id="@+id/product_name" android:layout_width="210dp" android:layout_height="wrap_content" android:layout_toRightOf="@+id/productImage" android:layout_marginTop="5dp" android:layout_marginLeft="5dp" android:text="Product Name" android:textAppearance="?android:attr/textAppearanceMedium" android:textColor="#000000" android:textSize="18dp" /> <TextView android:id="@+id/product_mrp" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toRightOf="@+id/productImage" android:layout_below="@+id/product_name" android:layout_marginTop="5dp" android:layout_marginLeft="5dp" android:text="MRP:" android:textColor="#000000" android:textAppearance="?android:attr/textAppearanceMedium" android:textSize="14dp" /> <TextView android:id="@+id/product_mrpvalue" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toRightOf="@+id/product_mrp" android:layout_below="@+id/product_name" android:layout_marginTop="5dp" android:layout_marginLeft="5dp" android:text="Rs 100" android:textColor="#000000" android:textAppearance="?android:attr/textAppearanceMedium" android:textSize="14dp" /> <TextView android:id="@+id/product_bb" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toRightOf="@+id/product_mrpvalue" android:layout_below="@+id/product_name" android:layout_marginTop="5dp" android:layout_marginLeft="20dp" android:text="BB Price:" android:textAppearance="?android:attr/textAppearanceMedium" android:textColor="#000000" android:textSize="14dp" /> <TextView android:id="@+id/product_bbvalue" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toRightOf="@+id/product_bb" android:layout_below="@+id/product_name" android:layout_marginTop="5dp" android:layout_marginLeft="5dp" android:text="Rs 95" android:textAppearance="?android:attr/textAppearanceMedium" android:textColor="#000000" android:textSize="14dp" /> <Button android:id="@+id/add_cart" android:layout_width="40dp" android:layout_height="40dp" android:layout_below="@+id/matching_product" android:layout_alignParentRight="true" android:layout_marginRight ="10dp" android:gravity="center" android:drawableLeft="@drawable/cart_low" style="?android:attr/borderlessButtonStyle" /> </RelativeLayout>
Place the barcode icon in the res/drawable-hdpi folder. Change the name of the file as barcode.jpg
Place the cart icon in the res/drawable-hdpi folder. Change the name of the file as cart_low.jpg
Update the code for Search.java
package com.zing.basket; package com.zing.basket; import java.util.ArrayList; import org.json.JSONArray; import org.json.JSONObject; import android.annotation.SuppressLint; import android.app.ProgressDialog; import android.content.Context; import android.graphics.Typeface; import android.os.AsyncTask; import android.os.Bundle; import android.support.v4.app.Fragment; import android.util.Log; import android.view.Gravity; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.Button; import android.widget.ImageButton; import android.widget.ListView; import android.widget.SearchView; import android.widget.SearchView.OnQueryTextListener; import android.widget.TextView; import android.widget.Toast; import com.zing.basket.util.Product; public class Search extends Fragment { View myFragmentView; SearchView search; ImageButton buttonBarcode; ImageButton buttonAudio; Typeface type; ListView searchResults; String found = "N"; //This arraylist will have data as pulled from server. This will keep cumulating. ArrayList<Product> productResults = new ArrayList<Product>(); //Based on the search string, only filtered products will be moved here from productResults ArrayList<Product> filteredProductResults = new ArrayList<Product>(); @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { //get the context of the HomeScreen Activity final HomeScreen activity = (HomeScreen) getActivity(); //define a typeface for formatting text fields and listview. type= Typeface.createFromAsset(activity.getAssets(),"fonts/book.TTF"); myFragmentView = inflater.inflate(R.layout.fragment_search, container, false); search=(SearchView) myFragmentView.findViewById(R.id.searchView1); search.setQueryHint("Start typing to search..."); searchResults = (ListView) myFragmentView.findViewById(R.id.listview_search); buttonBarcode = (ImageButton) myFragmentView.findViewById(R.id.imageButton2); buttonAudio = (ImageButton) myFragmentView.findViewById(R.id.imageButton1); //this part of the code is to handle the situation when user enters any search criteria, how should the //application behave? search.setOnQueryTextFocusChangeListener(new View.OnFocusChangeListener() { @Override public void onFocusChange(View v, boolean hasFocus) { // TODO Auto-generated method stub //Toast.makeText(activity, String.valueOf(hasFocus),Toast.LENGTH_SHORT).show(); } }); search.setOnQueryTextListener(new OnQueryTextListener() { @Override public boolean onQueryTextSubmit(String query) { // TODO Auto-generated method stub return false; } @Override public boolean onQueryTextChange(String newText) { if (newText.length() > 3) { searchResults.setVisibility(myFragmentView.VISIBLE); myAsyncTask m= (myAsyncTask) new myAsyncTask().execute(newText); } else { searchResults.setVisibility(myFragmentView.INVISIBLE); } return false; } }); return myFragmentView; } //this filters products from productResults and copies to filteredProductResults based on search text public void filterProductArray(String newText) { String pName; filteredProductResults.clear(); for (int i = 0; i < productResults.size(); i++) { pName = productResults.get(i).getProductName().toLowerCase(); if ( pName.contains(newText.toLowerCase()) || productResults.get(i).getProductBarcode().contains(newText)) { filteredProductResults.add(productResults.get(i)); } } } //in this myAsyncTask, we are fetching data from server for the search string entered by user. class myAsyncTask extends AsyncTask<String, Void, String> { JSONParser jParser; JSONArray productList; String url=new String(); String textSearch; ProgressDialog pd; @Override protected void onPreExecute() { super.onPreExecute(); productList=new JSONArray(); jParser = new JSONParser(); pd= new ProgressDialog(getActivity()); pd.setCancelable(false); pd.setMessage("Searching..."); pd.getWindow().setGravity(Gravity.CENTER); pd.show(); } @Override protected String doInBackground(String... sText) { url="http://lawgo.in/lawgo/products/user/1/search/"+sText[0]; String returnResult = getProductList(url); this.textSearch = sText[0]; return returnResult; } public String getProductList(String url) { Product tempProduct = new Product(); String matchFound = "N"; //productResults is an arraylist with all product details for the search criteria //productResults.clear(); try { JSONObject json = jParser.getJSONFromUrl(url); productList = json.getJSONArray("ProductList"); //parse date for dateList for(int i=0;i<productList.length();i++) { tempProduct = new Product(); JSONObject obj=productList.getJSONObject(i); tempProduct.setProductCode(obj.getString("ProductCode")); tempProduct.setProductName(obj.getString("ProductName")); tempProduct.setProductGrammage(obj.getString("ProductGrammage")); tempProduct.setProductBarcode(obj.getString("ProductBarcode")); tempProduct.setProductDivision(obj.getString("ProductCatCode")); tempProduct.setProductDepartment(obj.getString("ProductSubCode")); tempProduct.setProductMRP(obj.getString("ProductMRP")); tempProduct.setProductBBPrice(obj.getString("ProductBBPrice")); //check if this product is already there in productResults, if yes, then don't add it again. matchFound = "N"; for (int j=0; j < productResults.size();j++) { if (productResults.get(j).getProductCode().equals(tempProduct.getProductCode())) { matchFound = "Y"; } } if (matchFound == "N") { productResults.add(tempProduct); } } return ("OK"); } catch (Exception e) { e.printStackTrace(); return ("Exception Caught"); } } @Override protected void onPostExecute(String result) { super.onPostExecute(result); if(result.equalsIgnoreCase("Exception Caught")) { Toast.makeText(getActivity(), "Unable to connect to server,please try later", Toast.LENGTH_LONG).show(); pd.dismiss(); } else { //calling this method to filter the search results from productResults and move them to //filteredProductResults filterProductArray(textSearch); searchResults.setAdapter(new SearchResultsAdapter(getActivity(),filteredProductResults)); pd.dismiss(); } } } } class SearchResultsAdapter extends BaseAdapter { private LayoutInflater layoutInflater; private ArrayList<Product> productDetails=new ArrayList<Product>(); int count; Typeface type; Context context; //constructor method public SearchResultsAdapter(Context context, ArrayList<Product> product_details) { layoutInflater = LayoutInflater.from(context); this.productDetails=product_details; this.count= product_details.size(); this.context = context; type= Typeface.createFromAsset(context.getAssets(),"fonts/book.TTF"); } @Override public int getCount() { return count; } @Override public Object getItem(int arg0) { return productDetails.get(arg0); } @Override public long getItemId(int arg0) { return arg0; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder; Product tempProduct = productDetails.get(position); if (convertView == null) { convertView = layoutInflater.inflate(R.layout.listtwo_searchresults, null); holder = new ViewHolder(); holder.product_name = (TextView) convertView.findViewById(R.id.product_name); holder.product_mrp = (TextView) convertView.findViewById(R.id.product_mrp); holder.product_mrpvalue = (TextView) convertView.findViewById(R.id.product_mrpvalue); holder.product_bb = (TextView) convertView.findViewById(R.id.product_bb); holder.product_bbvalue = (TextView) convertView.findViewById(R.id.product_bbvalue); holder.addToCart = (Button) convertView.findViewById(R.id.add_cart); convertView.setTag(holder); } else { holder = (ViewHolder) convertView.getTag(); } holder.product_name.setText(tempProduct.getProductName()); holder.product_name.setTypeface(type); holder.product_mrp.setTypeface(type); holder.product_mrpvalue.setText(tempProduct.getProductMRP()); holder.product_mrpvalue.setTypeface(type); holder.product_bb.setTypeface(type); holder.product_bbvalue.setText(tempProduct.getProductBBPrice()); holder.product_bbvalue.setTypeface(type); return convertView; } static class ViewHolder { TextView product_name; TextView product_mrp; TextView product_mrpvalue; TextView product_bb; TextView product_bbvalue; TextView product_savings; TextView product_savingsvalue; TextView qty; TextView product_value; Button addToCart; } }
Why don't you post the entire project so that user can download it on a click
ReplyDeleteyes ur right
DeletePhp Code and Datbase ?
ReplyDeletecan u plz tell us the php code and data base .. how to configure rest api
ReplyDeleteplz code for php script........
ReplyDeleteI will post the script shortly on YouTube channel as well as here..
ReplyDelete