Thursday, 31 December 2015

Detect shake listener in android


     Here I am going to explain how to detect shake listener in android



Step 1).ShakeListener.java


import android.content.Context;
import android.hardware.SensorListener;
import android.hardware.SensorManager;

public class ShakeListener implements SensorListener 
{
    private static final int FORCE_THRESHOLD = 400;
    private static final int TIME_THRESHOLD = 120;
    private static final int SHAKE_TIMEOUT = 500;
    private static final int SHAKE_DURATION =1000;
    private static final int SHAKE_COUNT = 6;

    private SensorManager mSensorMgr;
    private float mLastX = -1.0f, mLastY = -1.0f, mLastZ = -1.0f;
    private long mLastTime;
    private OnShakeListener mShakeListener;
    private Context mContext;
    private int mShakeCount = 0;
    private long mLastShake;
    private long mLastForce;

    public interface OnShakeListener {
        public void onShake();
    }

    public ShakeListener(Context context) {
        mContext = context;
        resume();
    }

    public void setOnShakeListener(OnShakeListener listener) {
        mShakeListener = listener;
    }

    public void resume() {
         mSensorMgr =(SensorManager)
              mContext.getSystemService(Context.SENSOR_SERVICE);                                                                                          

      if (mSensorMgr == null) {
            throw new UnsupportedOperationException("Sensors not supported");
       }
     boolean supported =mSensorMgr.registerListener 
                         (this,  SensorManager.SENSOR_ACCELEROMETER,  
                         SensorManager.SENSOR_DELAY_GAME);                                                         
             if (!supported ) {
               mSensorMgr.unregisterListener
                    (this,SensorManager.SENSOR_ACCELEROMETER); 
  throw new UnsupportedOperationException("Accelerometer not supported");
        }
    }

    public void pause() {
        if (mSensorMgr != null) 
           {
            mSensorMgr .unregisterListener
                                (this, SensorManager.SENSOR_ACCELEROMETER);
            mSensorMgr = null;
        }
    }

    public void onAccuracyChanged(int sensor, int accuracy) {
    }

    public void onSensorChanged(int sensor, float[] values) {
        if (sensor != SensorManager.SENSOR_ACCELEROMETER) return;
        long now = System.currentTimeMillis();

        if ((now - mLastForce) > SHAKE_TIMEOUT) {
            mShakeCount = 0;
        }

        if ((now - mLastTime) > TIME_THRESHOLD) 
        {
            long diff = now - mLastTime;
            float speedMath.abs(values[SensorManager.DATA_X]
                                           +values[SensorManager.DATA_Y]
                                           +values[SensorManager.DATA_Z] 
                             - mLastX mLastY - mLastZ) / diff * 10000;                                                                                                                                                                             


           if (speed > FORCE_THRESHOLD) 
           {
           if ((++mShakeCount >= SHAKE_COUNT) && (now -                                                                                             mLastShake>SHAKE_DURATION)) 
            {
                    mLastShake = now;
                    mShakeCount = 0;
                    if (mShakeListener != null) 
                    {
                        mShakeListener.onShake();
                    }
                }
                mLastForce = now;
            }
            mLastTime = now;
            mLastX = values[SensorManager.DATA_X];
            mLastY = values[SensorManager.DATA_Y];
            mLastZ = values[SensorManager.DATA_Z];
        }
    }

}


Step 2)Use below steps in your activity

   private ShakeListener mShaker;


         mShaker= new ShakeListener(this);
         mShaker.setOnShakeListener(new ShakeListener.OnShakeListener() {
            public void onShake() 
              {
                          //To do something
              }

Happy Coding;)

Read Google Chrome history in android


  Here I am going to explain how to read google chrome history in android studio IDE


  private void getBrowserHistory() {

  final Uri BOOKMARKS_URI; 
          
          BOOKMARKS_URI=Uri.parse("content://android.chrome.browser/bookmarks");     
         final String[] HISTORY_PROJECTION = new String[]
         {
                "_id", // 0
                "url", // 1
                "visits", // 2
                "date", // 3
                "bookmark", // 4
                "title", // 5
                "favicon", // 6
                "thumbnail", // 7
                "touch_icon", // 8
                "user_entered", // 9
        };


  Cursor mCur = this.managedQuery(BOOKMARKS_URIHISTORY_PROJECTION, null,     null,null);
        this.startManagingCursor(mCur );
        mCur .moveToFirst();

        String title = "";
        String url = "";
        String date="";

        if (mCur.moveToFirst() && mCur.getCount() > 0) {
            while (mCur.isAfterLast() == false ) {

                title= mCur.getString(mCur .getColumnIndex("title"));
                url = mCur.getString(mCur .getColumnIndex("url"));
                date= mCur.getString(mCur .getColumnIndex("date"));

              

                mCur .moveToNext();
            }
        }
}


Add the below permission to your Manifest file.

<uses-permission android:name="com.android.browser.permission.READ_HISTORY_BOOKMARKS"/>


Happy Coding:)

Wednesday, 30 December 2015

Lock phone Programmatically android


    Here I am going to explain how to lock our phone Programmatically in android.



   

                                 




Step 1).MainActivity.java

import android.app.admin.DevicePolicyManager;
import android.content.ComponentName;
import android.content.Intent;
import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;


public class MainActivity extends AppCompatActivity {

    private DevicePolicyManager devicePolicyManager = null;
    private ComponentName componentName = null;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
       super.onCreate(savedInstanceState);
       setContentView(R.layout.activity_main);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

      componentName = new ComponentName(this, AdminReceiver.class);
      devicePolicyManager =(DevicePolicyManager)
                                       getSystemService(DEVICE_POLICY_SERVICE);
      lock();                                                                                                            FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view)
            {

                devicePolicyManager.lockNow();

            }
        });
    }
    public void lock()
    {

             Intent intent =new Intent
                 (DevicePolicyManager.ACTION_ADD_DEVICE_ADMIN);
             intent.putExtra(DevicePolicyManager.EXTRA_DEVICE_ADMIN,                                                                                           componentName);
             intent.putExtra(DevicePolicyManager.EXTRA_ADD_EXPLANATION,"");
                
             startActivity(intent);

    }

}

Step 2).AdminReceiver.java

import android.app.admin.DeviceAdminReceiver;

public class AdminReceiver extends DeviceAdminReceiver
{


}


Step 3).Register receiver in your Manifest file


      <receiver
            android:name="AdminReceiver"
            android:permission="android.permission.BIND_DEVICE_ADMIN">
            <meta-data
                android:name="android.app.device_admin"
                android:resource="@xml/device_admin" />

            <intent-filter>
             <action  
                android:name="android.app.action.DEVICE_ADMIN_ENABLED" />
             </intent-filter>
        </receiver>
   
      <uses-feature
        android:name="android.software.device_admin"
        android:required="true" />

Happy Coding:)

How to send SMS in android without user interaction


       Here I am going to explain how to send text message(SMS) in android without user interaction.


Step 1).Declare BroadCastReceiver and PendingIntent in your actvity;


    BroadcastReceiver sendBroadcastReceiver;
    BroadcastReceiver deliveryBroadcastReceiver;
    PendingIntent deliveredPI;
    PendingIntent sentPI;


Step 2).Call this function


   private void sendSMS(String phoneNumber, String message) {
        String SENT = "SMS_SENT";
        String DELIVERED = "SMS_DELIVERED";

        sentPI= PendingIntent.getBroadcast(this, 0, new Intent(SENT), 0);
               

       deliveredPI= PendingIntent.getBroadcast(this, 0,                                                                                                        newIntent(DELIVERED),0);                   
        //---SMS has been sent---
        sendBroadcastReceiver= new BroadcastReceiver() {
            @Override
            public void onReceive(Context arg0, Intent arg1) {
                switch (getResultCode()) {
                    case Activity.RESULT_OK:
                        Toast.makeText(getBaseContext(), "SMS sent",
                                Toast.LENGTH_SHORT).show();
                        break;
                    case SmsManager.RESULT_ERROR_GENERIC_FAILURE:
                        Toast.makeText(getBaseContext(), "Generic failure",
                                Toast.LENGTH_SHORT).show();
                        break;
                    case SmsManager.RESULT_ERROR_NO_SERVICE:
                        Toast.makeText(getBaseContext(), "No service",
                                Toast.LENGTH_SHORT).show();
                        break;
                    case SmsManager.RESULT_ERROR_NULL_PDU:
                        Toast.makeText(getBaseContext(), "Null PDU",
                                Toast.LENGTH_SHORT).show();
                        break;
                    case SmsManager.RESULT_ERROR_RADIO_OFF:
                        Toast.makeText(getBaseContext(), "Radio off",
                                Toast.LENGTH_SHORT).show();
                        break;
                }
            }
        };
        registerReceiver(sendBroadcastReceiver, new IntentFilter(SENT));
        //---when the SMS has been delivered---
        deliveryBroadcastReceiver= new BroadcastReceiver() {
            @Override
            public void onReceive(Context arg0, Intent arg1) {
                switch (getResultCode()) {
                    case Activity.RESULT_OK:
                        Toast.makeText(getBaseContext(), "SMS delivered",
                                Toast.LENGTH_SHORT).show();
                        break;
                    case Activity.RESULT_CANCELED:
                        Toast.makeText(getBaseContext(), "SMS not delivered",
                                Toast.LENGTH_SHORT).show();
                        break;
                }
            }
        };


       registerReceiver(deliveryBroadcastReceiver, new IntentFilter(DELIVERED));
       SmsManager sms = SmsManager.getDefault();
       sms.sendTextMessage(phoneNumber, null,message sentPI, deliveredPI);

    }


Step 3) UnRegister the receiver 

   @Override
    protected void onStop() {
        try {
            if (sentPI != null) {
                unregisterReceiver(sendBroadcastReceiver);
                sentPI = null;
            }

            if (deliveredPI != null) {
                unregisterReceiver(deliveryBroadcastReceiver);
                deliveredPI =null;
            }
        } catch (Exception e) {

        }
        super.onStop();
    }

Step 4)Add SMS permission in your Manifest file

 <uses-permission android:name="android.permission.SEND_SMS" />


And Make Sure you have SMS plan


Happy coding:)

  

Monday, 21 December 2015

Android studio read browser history

  Here I am going to explain how to read browser history from android



 private void getBrowserHistory() {

         final Uri BOOKMARKS_URI = Uri.parse("content://browser/bookmarks");
         final String[] HISTORY_PROJECTION = new String[]
         {
                "_id", // 0
                "url", // 1
                "visits", // 2
                "date", // 3
                "bookmark", // 4
                "title", // 5
                "favicon", // 6
                "thumbnail", // 7
                "touch_icon", // 8
                "user_entered", // 9
        };


  Cursor mCur = this.managedQuery(BOOKMARKS_URI, HISTORY_PROJECTION, null,   null,null);
        this.startManagingCursor(mCur );
        mCur .moveToFirst();

        String title = "";
        String url = "";
        String date="";

        if (mCur.moveToFirst() && mCur.getCount() > 0) {
            while (mCur.isAfterLast() == false ) {

                title= mCur.getString(mCur .getColumnIndex("title"));
                url = mCur.getString(mCur .getColumnIndex("url"));
                date= mCur.getString(mCur .getColumnIndex("date"));

              

                mCur .moveToNext();
            }
        }
}


Add the below permission to your Manifest file.

<uses-permission android:name="com.android.browser.permission.READ_HISTORY_BOOKMARKS"/>


Happy Coding:)