Tuesday, 24 February 2015

AutoComplete TextBox in Android

In this blog, I will show how to achieve AutoComplete TextBox property, and how it works.

Java Code:


MainActivity.java

package com.example.autocomplete;

import java.util.ArrayList;

import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.text.Editable;
import android.text.TextWatcher;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ArrayAdapter;
import android.widget.AutoCompleteTextView;
import android.widget.Button;
import android.widget.ListView;
import android.widget.Toast;

public class MainActivity extends Activity implements TextWatcher {
    AutoCompleteTextView autocomplete;
    ListView listview;
    ArrayList<String> listitems = new ArrayList<String>();
    SQLiteDatabase sqlitedatabase;
    Button save, cancel;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        sqlitedatabase = this
                .openOrCreateDatabase("sample", MODE_PRIVATE, null);
        try {
            sqlitedatabase
                    .execSQL("create table if not exists student(name varchar(30))");
                   } catch (Exception e) {
            System.err.println("error" + e.toString());
        }
        save = (Button) findViewById(R.id.btnsave);
        save.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View arg0) {
                // TODO Auto-generated method stub
                String value = autocomplete.getText().toString();
                try {
                    sqlitedatabase.execSQL("insert into student (name) values('"
                            + value + "')");
                    Toast.makeText(getApplicationContext(), "value stored",
                            Toast.LENGTH_SHORT).show();
                                      Intent intent = new Intent(MainActivity.this,
                            MainActivity.class);
                    startActivity(intent);
                } catch (Exception ex) {
                    System.err.println("error");
                }

            }
        });
        cancel = (Button) findViewById(R.id.btncancel);
        cancel.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                Intent intent = new Intent(MainActivity.this,
                        MainActivity.class);
                startActivity(intent);

            }
        });
        Cursor c = sqlitedatabase.rawQuery("select distinct name from student",
                null);

        if (c != null) {
            if (c.moveToFirst()) {
                do {
                    String Auto = c.getString(c.getColumnIndex("name"));
                    listitems.add(Auto);
                } while (c.moveToNext());
            }

        }
        c.close();

        final String[] arrayOfStrings;
        arrayOfStrings = listitems.toArray(new String[listitems.size()]);
        autocomplete = (AutoCompleteTextView) findViewById(R.id.autoCompleteTextView1);
        autocomplete.setAdapter(new ArrayAdapter<String>(this,
                android.R.layout.simple_list_item_1, android.R.id.text1,
                arrayOfStrings));

    }

    @Override
    public void afterTextChanged(Editable arg0) {
        // TODO Auto-generated method stub

    }

    @Override
    public void beforeTextChanged(CharSequence arg0, int arg1, int arg2,
            int arg3) {
        // TODO Auto-generated method stub

    }

    @Override
    public void onTextChanged(CharSequence arg0, int arg1, int arg2, int arg3) {
        // TODO Auto-generated method stub

    }
}


activity_main.xml

  <AutoCompleteTextView
        android:id="@+id/autoCompleteTextView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_margin="10dp"
        android:completionThreshold="1"
        android:ems="10" >

        <requestFocus />
    </AutoCompleteTextView>

    <TextView
        android:id="@+id/txtviewenter"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_marginTop="30dp"
        android:paddingRight="2dp"
        android:text="Enter Text"
        android:textSize="20sp" />

    <LinearLayout
        android:id="@+id/buttonlayout"
        android:layout_width="fill_parent"
        android:layout_height="50dp"
        android:layout_alignParentBottom="true"
        android:layout_margin="5dp"
        android:orientation="horizontal" >

        <Button
            android:id="@+id/btnsave"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:text="Save"
            android:textSize="20sp"
            android:textStyle="bold" >
        </Button>

        <Button
            android:id="@+id/btncancel"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:text="Cancel"
            android:textSize="20sp"
            android:textStyle="bold" >
        </Button>
    </LinearLayout>

    <ListView
        android:id="@+id/listView"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:visibility="invisible" />


 Screen Shots:

 Save text in Local database.

Again open the application, try to enter the text, the available words starts with the letter entered pop ups.













Monday, 23 February 2015

Android Camera Application

In this blog, I will show how to use default camera application in our application

Java Code:

Sample.java

package com.example.eventorganize;

import android.app.Activity;
import android.content.Intent;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ImageView;

public class Sample extends Activity {
    ImageView imgphoto;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_sample);
        imgphoto = (ImageView) findViewById(R.id.imgphoto);
        imgphoto.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                capture();
            }
        });
    }
    protected void capture() {
        // TODO Auto-generated method stub
        Intent intent = new Intent(
                android.provider.MediaStore.ACTION_IMAGE_CAPTURE);
        startActivityForResult(intent, 0);
    }
   
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        System.err.println("code:" + data);
        if (data != null) {
            Bitmap bp = (Bitmap) data.getExtras().get("data");
            imgphoto.setImageBitmap(bp);
        }
    }
}


activity_sample.xml

 <ImageView
        android:id="@+id/imgphoto"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_margin="5dp"
        android:background="@drawable/capture"
        android:contentDescription="@string/app_name"
        android:scaleType="fitXY" />

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:text="@string/tap"
        android:textAppearance="?android:attr/textAppearanceLarge" />


strings.xml

<string name="tap">Tap here to capture Photo</string>


Screen Shots: