Wednesday 25 March 2015

Dynamically Adding the Spinner and Edittext with Delete



Dynamically Adding the Spinner and Edittext with Delete


Programmatically Adding n Number of spinner and editext button with delete button





Main Activity:-

package com.example.dynamiccreation;

import java.io.BufferedInputStream;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.app.Activity;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.view.ViewGroup.LayoutParams;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemSelectedListener;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.ScrollView;
import android.widget.SimpleCursorAdapter;
import android.widget.Spinner;
import android.widget.Toast;

public class MainActivity extends Activity {
    Context context;
    ScrollView scrollView;
    LinearLayout container;
    LinearLayout layout,hor_layout;
   
     int i = 1;
   
    ArrayAdapter<String> dataAdapter;
   
    List<EditText> allEds ;
   
    List<Spinner> allSpinner ;
   
    
   
     List<String> list;
    
    
     private String[] productId = {};
     private String[] product = {};
     private String[] qty = {};
    
    
    
     ArrayList<String> list_productId = new ArrayList<String>();   
     ArrayList<String> list_product;
     ArrayList<String> list_qty = new ArrayList<String>();
    
    
    SQLiteDatabase db = null;
    
   
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        context = this;
        setContentView(R.layout.activity_main);
        layout = (LinearLayout) findViewById(R.id.layout_horittal);
        
        
        db = openOrCreateDatabase("dynamic.db", MODE_PRIVATE, null);
         String sql_create = "create table if not exists valuecheck(_id integer primary key autoincrement,spinner varchar(120),qty varchar(120))";
         String sql_product = "create table if not exists product(_id integer primary key autoincrement,productid varchar(120),product varchar(120),qty varchar(120))";
        
         db.execSQL(sql_create);
         db.execSQL(sql_product);
        
        allEds = new ArrayList<EditText>();
        
        list_product = new ArrayList<String>();
        list_product.add("Select Proudct");
       
        allSpinner = new ArrayList<Spinner>();
        
         String spinner_value[] = {"A","B","C","D","E","F","G","H","I"};
        
          list = new ArrayList<String>();
         list.add("A+");
         list.add("A");
         list.add("B");
         list.add("C");
         list.add("D");
         list.add("E");
         list.add("f");
         list.add("G");
         list.add("I");
         list.add("J");
         list.add("K");
         list.add("L");
        
         dataAdapter = new ArrayAdapter<String>(this,android.R.layout.simple_spinner_item, list_product);
         dataAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
        
         String url = "http://192.168.2.16/mjn/roycerest/pick_productinput.php?module=mktgproductallocation&pickname=products&user=5007456";
           
         Log.e("url for android", "======"+url);
           
           
         new AsyncHttpTask().execute(url);
           
           
    }

    public void addButton(View view) {
       
       
       
         final LinearLayout lin_layout = new LinearLayout(MainActivity.this);
         lin_layout.setOrientation(LinearLayout.HORIZONTAL);
            
            final Spinner spinner = new Spinner(MainActivity.this);
         final EditText edittext = new EditText(MainActivity.this);
         edittext.setHint("Please file the value");
       
         final Button btn_get = new Button(MainActivity.this);
         btn_get.setText("Delete");
        
               
         spinner.setOnItemSelectedListener(new OnItemSelectedListener() {
             @Override
             public void onItemSelected(AdapterView<?> parentView, View selectedItemView, int position, long id) {

                     int iv = 0;
               
                   String spin_value = spinner.getSelectedItem().toString();  
                   int spinner_id =  spinner.getId();
                  
                 if(!(spin_value.equals("Select Proudct")))
                 {
                    if(spinner_id>=1)
                    {
                        for(int ij = 0;ij<allSpinner.size();ij++)
                        {
                            String spinnervalue = allSpinner.get(ij).getSelectedItem().toString();
                                if(spin_value.equals(spinnervalue))
                                {
                                    iv++;
                                }
                        }
                        if(iv>=2)
                        {
                             spinner.setAdapter(dataAdapter);
                            Toast.makeText(getApplicationContext(), "Please select different product", Toast.LENGTH_SHORT).show();
                        }
                    }
                 }
             }

             @Override
             public void onNothingSelected(AdapterView<?> parentView) {
                 // your code here
             }

         });

        
        
         final Button btn_Saveas = new Button(MainActivity.this);
         btn_Saveas.setText("Save As");
       
            btn_get.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                   
                //    ((LinearLayout)layout.getParent()).removeView(lp);
                   
                    lin_layout.removeView(btn_get);
                    lin_layout.removeView(edittext);
                    lin_layout.removeView(spinner);
                   
                    allEds.remove(edittext);
                   
                    allSpinner.remove(spinner);
                   
//                    int  ading = spinner.getId();
//                   
//                    String edit_value = edittext.getText().toString();
//                   
                    Toast.makeText(getApplicationContext(), "hello", Toast.LENGTH_SHORT).show();


                }
            });
           
            LayoutParams lp = new LayoutParams(LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT);
           
            spinner.setLayoutParams(lp);
            edittext.setLayoutParams(lp);
            btn_get.setLayoutParams(lp);
            spinner.setAdapter(dataAdapter);
           
            spinner.setId(i);
            edittext.setId(i);
            btn_get.setId(i);
           
            allEds.add(edittext);
            allSpinner.add(spinner);
           
           
            lin_layout.addView(spinner);
            lin_layout.addView(edittext);
            lin_layout.addView(btn_get);
            layout.addView(lin_layout);
           
            i++;
    }

    public void saveButton(View view)
    {
       
        String inse_delete = "DELETE FROM valuecheck";
    //    String inse_alter ="ALTER TABLE valuecheck AUTO_INCREMENT = 1";
        db.execSQL(inse_delete);
        //db.execSQL(inse_alter);
       
            for(int i=0; i < allEds.size(); i++)
            {
                int id = allEds.get(i).getId();
                String edittestvalue = allEds.get(i).getText().toString();
                String spinnervalue = allSpinner.get(i).getSelectedItem().toString();
               
                Log.i(" ID===>", "ID==========>"+id);
               
                Toast.makeText(getApplicationContext(),"Spinner"+spinnervalue+"Edit Text"+edittestvalue, Toast.LENGTH_SHORT).show();
               
                Log.v(" vvvvvvvvvvvvvv==>Get All Value Dynamically", "Spinner"+spinnervalue+"Edit Text"+edittestvalue);
               
                Log.i(" iiiiiiiiiiiii===> Get All Value Dynamically", "Spinner"+spinnervalue+"Edit Text"+edittestvalue);

                String inse_query = "insert into valuecheck(spinner,qty) values('"+spinnervalue+"','"+edittestvalue+"')";
           
                db.execSQL(inse_query);
           
                Log.d("Insert query for valuecheck", ""+inse_query);
               
            }
           
    }
   
   
   
    public void updateButton(View view)
    {
           
        String inse_select = "SELECT * FROM valuecheck";
        Cursor cr_value = db.rawQuery(inse_select, null);
       
        if(cr_value.getCount()>0)
        {
            while(cr_value.moveToNext())
            {
               
                 final LinearLayout lin_layout1 = new LinearLayout(MainActivity.this);
                 lin_layout1.setOrientation(LinearLayout.HORIZONTAL);
                    
                    final Spinner spinner1 = new Spinner(MainActivity.this);
                 final EditText edittext1 = new EditText(MainActivity.this);
                 edittext1.setHint("Please Fill the value");
               
                 final Button btn_get1 = new Button(MainActivity.this);
                 btn_get1.setText("Delete");
                
                 layout.removeView(lin_layout1);
                
                    btn_get1.setOnClickListener(new View.OnClickListener() {
                        @Override
                        public void onClick(View v) {
                           
                        //    ((LinearLayout)layout.getParent()).removeView(lp);
                           
                            lin_layout1.removeView(btn_get1);
                            lin_layout1.removeView(edittext1);
                            lin_layout1.removeView(spinner1);
                           
                            allEds.remove(edittext1);
                           
                            allSpinner.remove(spinner1);
//                            int  ading = spinner.getId();
//                           
//                            String edit_value = edittext.getText().toString();
//                           
//                            Toast.makeText(getApplicationContext(), ""+ading+" "+edit_value, Toast.LENGTH_SHORT).show();
//                           
                        }
                    });
               
                    LayoutParams lp = new LayoutParams(LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT);
                   
                   
               
                    int ids = cr_value.getInt(cr_value.getColumnIndex("_id"));
               
                    String s_val = cr_value.getString(cr_value.getColumnIndex("spinner"));
                    String e_val = cr_value.getString(cr_value.getColumnIndex("qty"));
                   
                   
                    spinner1.setLayoutParams(lp);
                    edittext1.setLayoutParams(lp);
                    btn_get1.setLayoutParams(lp);
                    spinner1.setAdapter(dataAdapter);
                   
                    spinner1.setSelection(getIndex(spinner1, s_val));
                    edittext1.setText(e_val);
                   
                   // SelectSpinnerItemByValue(spinner1, s_val);
                   
                    Log.i("=======================id============",""+ids);
                   
                   
                   
                    spinner1.setId(i);
                    edittext1.setId(i);
                    btn_get1.setId(i);
//                   
                    allEds.add(edittext1);
                    allSpinner.add(spinner1);
                   
                   
                    lin_layout1.addView(spinner1);
                    lin_layout1.addView(edittext1);
                    lin_layout1.addView(btn_get1);
                    layout.addView(lin_layout1);
                   
                   
                i++;
               
            }
           
        }
        else
        {
            Toast.makeText(getApplicationContext(), "There is No Record in this Table", Toast.LENGTH_SHORT).show();
        }
       
    }
   
//    public static void SelectSpinnerItemByValue(Spinner spnr, String value)
//    {
//        SimpleCursorAdapter adapter = (SimpleCursorAdapter) spnr.getAdapter();
//        for (int position = 0; position < adapter.getCount(); position++)
//        {
//            if(adapter.getItemId(position) == value)
//            {
//                spnr.setSelection(position);
//                return;
//            }
//        }
//    }
//   
   
    private int getIndex(Spinner spinner1, String myString){

        int index = 0;

        for (int i=0;i<spinner1.getCount();i++){
            if (spinner1.getItemAtPosition(i).equals(myString)){
                index = i;
            }
        }
        return index;
 }
   
   
    public void jsonButton(View view)
    {
       
       
       
       
       
       
    }
   
   
    public class AsyncHttpTask extends AsyncTask<String, Void, Integer>
    {
        @Override
        protected Integer doInBackground(String... params)
        {
                InputStream inputStream = null;
                HttpURLConnection urlConnection = null;
                Integer result = 0;
            try
            {
                /* forming th java.net.URL object */
                URL url = new URL(params[0]);
                urlConnection = (HttpURLConnection) url.openConnection();
                /* optional request header */
                urlConnection.setRequestProperty("Content-Type", "application/json");
                /* optional request header */
                urlConnection.setRequestProperty("Accept", "application/json");
                /* for Get request */
                urlConnection.setRequestMethod("GET");
                int statusCode = urlConnection.getResponseCode();
                /* 200 represents HTTP OK */
                if (statusCode == 200) {
                inputStream = new BufferedInputStream(urlConnection.getInputStream());
                String response = convertInputStreamToString(inputStream);
                parseResult(response);
                result = 1; // Successful
                }else{
                result = 0; //"Failed to fetch data!";
                }
            }
            catch (Exception e)
            {
                Log.d("", e.getLocalizedMessage());
            }
            return result; //"Failed to fetch data!";
        }
        @SuppressWarnings("unchecked")
        @Override
        protected void onPostExecute(Integer result) {
        /* Download complete. Lets update UI */
        if(result == 1){
       
           
           

        }else{
        Log.e("", "Failed to fetch data!");
        }
        }
    }
    private String convertInputStreamToString(InputStream inputStream) throws IOException
    {
        BufferedReader bufferedReader = new BufferedReader( new InputStreamReader(inputStream));
        String line = "";
        String result = "";
        while((line = bufferedReader.readLine()) != null){
        result += line;
        }
        /* Close Stream */
        if(null!=inputStream){
        inputStream.close();
        }
        return result;
    }

        private void parseResult(String result)
        {
           
            String inse_delete = "DELETE FROM product";
            db.execSQL(inse_delete);
           
           
           
            try
            {
                JSONObject response = new JSONObject(result);
               
                JSONObject response1 = response.getJSONObject("message");
               
                String su_msg = response1.getString("success");
               
                if(su_msg.equals("true"))
                {
                    //JSONArray posts = response1.optJSONArray("data");
                   
                    JSONArray pose = response1.getJSONArray("data");
                   
                    productId = new String[pose.length()];
                    product = new String[pose.length()];
                    qty = new String[pose.length()];
                   
                    for(int i=0; i< pose.length();i++ )
                    {
                        //JSONObject post = posts.optJSONObject(i);
                        JSONObject post1 = pose.optJSONObject(i);
                        String d_productId= post1.getString("mktgproductallocationid");
                        String d_product = post1.optString("mktgproductallocationname");
                        String d_qty = post1.optString("quntity");
                       
                        Log.e("===================", ""+d_productId);
                       
                       
                       
                        productId[i] = ""+d_productId.toString();
                        product[i] = ""+d_product.toString();
                        qty[i] = ""+d_qty;
                       
                        list_productId.add(d_productId);
                        list_product.add(d_product);
                        list_qty.add(d_qty);
                       
                       
                        String inse_product = "insert into product(productid,product,qty) values('"+d_productId+"','"+d_product+"','"+d_qty+"')";
                       
                        db.execSQL(inse_product);
                       
                        Log.i("================inser proucet",""+inse_product);

                       
                    }
                }
                else
                {
                    String str1 = "There is no value";
                   
                }
           
            }
            catch (JSONException e)
            {
                e.printStackTrace();
            }
        }
   
   
   
   
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

   
}




activity_main.xml


<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity" >

    <LinearLayout
        android:id="@+id/LinearAdd"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="70"
        android:orientation="horizontal" >

        <Button
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="0.50"
            android:onClick="addButton"
            android:text="click to add" />

        <Button
            android:id="@+id/update_btn"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="0.50"
            android:onClick="updateButton"
            android:text="update" />

        <Button
            android:id="@+id/btn_jsonvalue"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="0.50"
            android:onClick="jsonButton"
            android:text="Json Value" />

    </LinearLayout>

    <ScrollView
        android:id="@+id/scrollView1"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="70" >

        <LinearLayout
            android:id="@+id/layout_view"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical" >

            <LinearLayout
                android:id="@+id/layout_horittal"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:orientation="vertical" >

            </LinearLayout>

            <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:orientation="vertical" >

                <Button
                    android:id="@+id/btn_save_all"
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:onClick="saveButton"
                    android:text="Save" />

            </LinearLayout>

        </LinearLayout>
    </ScrollView>

</LinearLayout>



Results:


















 this one another























Tuesday 17 March 2015

Hide the app's icon after installed one apk


                               
                                              Hide app's icon inside the Home's Screen

     Hide the app's icon after installed one apk.(hide application icon in home)



PackageManager p = getPackageManager();

        ComponentName componentName = new ComponentName(this, com.talentcodeworks.callrecorder.CallRecorder.class);        p.setComponentEnabledSetting(componentName,PackageManager.COMPONENT_ENABLED_STATE_DISABLED, PackageManager.DONT_KILL_APP);
       


Explanation : -


PackageManager p = getPackageManager();  // p Reference for the PackageManager


ComponentName componentName = new ComponentName(this, com.apps.MainActivity.class); // activity which is first time open in manifiest file which is declare as <category android:name="android.intent.category.LAUNCHER" />

p.setComponentEnabledSetting(componentName,PackageManager.COMPONENT_ENABLED_STATE_DISABLED, PackageManager.DONT_KILL_APP);