Tuesday, 21 November 2017

How to use google Map in fragment


      In the latest update of Google for Maps, only MapView is supported for fragments. 


content_map.xml

    <?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" >

    <com.google.android.gms.maps.MapView
        android:id="@+id/mapView"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />
   </RelativeLayout>

Map.xml

  public class Map extends Fragment {

    MapView mMapView;
    private GoogleMap googleMap;
    

    ArrayList<LatLng> markerPoints;

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle                                                                          savedInstanceState) 
   {
        View rootView = inflater.inflate(R.layout.content_map, container, false);

        mMapView= (MapView) rootView.findViewById(R.id.mapView);
        mMapView.onCreate(savedInstanceState);

        mMapView.onResume();

        try {
            MapsInitializer.initialize(getActivity().getApplicationContext());
        } catch (Exception e) {
            e.printStackTrace();
        }

        mMapView.getMapAsync(new OnMapReadyCallback() {
            @Override
            public void onMapReady(GoogleMap mMap) {
                googleMap = mMap;


                if (checkLocationPermission()) {
                    if (ContextCompat.checkSelfPermission(getActivity(),
                            Manifest.permission.ACCESS_FINE_LOCATION)
                            == PackageManager.PERMISSION_GRANTED) {

                        //Request location updates:
                        googleMap.setMyLocationEnabled(true);
                    }
                }


                markerPoints = new ArrayList<LatLng>();

                googleMap.getUiSettings().setCompassEnabled(true);
                googleMap.getUiSettings().setMyLocationButtonEnabled(true);
                googleMap.getUiSettings().setRotateGesturesEnabled(true);
                // For dropping a marker at a point on the Map
                LatLng sydney = new LatLng(Float.parseFloat("Lat"),                                                                                     Float.parseFloat("Long"));
                googleMap.addMarker(new MarkerOptions().position(sydney).
                 title("Title").snippet("TitleName"));

                // For zooming automatically to the location of the marker
                 CameraPosition cameraPosition =                                                                           new CameraPosition.Builder().target(sydney).zoom(12).build(); 
                  googleMap.animateCamera(CameraUpdateFactory.newCameraPosition
                  (cameraPosition ));
                     
                                              

               }
           });

        return rootView;
    }

    @Override
    public void onResume() {
        super.onResume();
        mMapView.onResume();
    }

    @Override
    public void onPause() {
        super.onPause();
        mMapView.onPause();
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
        mMapView.onDestroy();
    }

    @Override
    public void onLowMemory() {
        super.onLowMemory();
        mMapView.onLowMemory();
    }

    public boolean checkLocationPermission() {
        if (ContextCompat.checkSelfPermission(getActivity(),
                Manifest.permission.ACCESS_FINE_LOCATION)
                != PackageManager.PERMISSION_GRANTED) {

            // Should we show an explanation?
            if (ActivityCompat.shouldShowRequestPermissionRationale(getActivity(),
                    Manifest.permission.ACCESS_FINE_LOCATION)) {

                // Show an explanation to the user *asynchronously* -- don't block
                // this thread waiting for the user's response! After the user
                // sees the explanation, try again to request the permission.
                new AlertDialog.Builder(getActivity())
                        .setTitle("")
                        .setMessage("")
                        .setPositiveButton("Ok", new DialogInterface.OnClickListener() {
                            @Override
                            public void onClick(DialogInterface dialogInterface, int i) {
                                //Prompt the user once explanation has been shown
                                ActivityCompat.requestPermissions(getActivity(),new String[]
                                 {Manifest.permission.ACCESS_FINE_LOCATION},1);                                                   
                            }
                        })
                        .create()
                        .show();


            } else {
                // No explanation needed, we can request the permission.
                ActivityCompat.requestPermissions(getActivity(),
                        new String[]{Manifest.permission.ACCESS_FINE_LOCATION},
                        1);
            }
            return false;
        } else {
            return true;
        }
    }

    @Override
    public void onRequestPermissionsResult(int requestCode,
                                           String permissions[], int[] grantResults) {
        switch (requestCode) {
            case 1:
                {
                // If request is cancelled, the result arrays are empty.
                if (grantResults.length > 0
                        && grantResults[0] == PackageManager.PERMISSION_GRANTED) {

                    // permission was granted, yay! Do the
                    // location-related task you need to do.
                    if (ContextCompat.checkSelfPermission(getActivity(),
                            Manifest.permission.ACCESS_FINE_LOCATION)
                            == PackageManager.PERMISSION_GRANTED) {


                        googleMap.setMyLocationEnabled(true);
                    }

                } else {



                }
                return;
            }

        }
    }

  }

Happy Coding:)

Thursday, 26 October 2017

Cannot resolve symbol 'LocationServices'


  Here I am going to explain how to fix 'Cannot resolve symbol LocationServices'


You need to import:

import com.google.android.gms.location.LocationServices;


Add in build.gradle:

compile 'com.google.android.gms:play-services-location:11.0.2'


Happy Coding :)

Tuesday, 14 March 2017

Resize Android image without losing quality


   Here I am going to explain how to convert image into scaled bitmap without losing quality




 public Bitmap resizeBitmap(String photoPath, int targetW, int targetH)
 {
        BitmapFactory.Options bmOptions = new BitmapFactory.Options();
        bmOptions.inJustDecodeBounds = true;
        BitmapFactory.decodeFile(photoPath, bmOptions);
        int photoW = bmOptions.outWidth;
        int photoH = bmOptions.outHeight;

        int scaleFactor = 1;
        if ((targetW > 0) || (targetH > 0)) {
            scaleFactor = Math.min(photoW/targetW, photoH/targetH);
        }

        bmOptions.inJustDecodeBounds = false;
        bmOptions.inSampleSize = scaleFactor;
        bmOptions.inPurgeable = true; //Deprecated API 21

        return BitmapFactory.decodeFile(bmOptionsphotoPath);
    }


Happy coding :)

Pass LinkedHashMap between activities


                   Here I am going to explain how to pass LikedHashMap data between activity.Before that we need to know GSON.Google Gson is a simple Java-based library to serialize Java objects to JSON and vice versa.

Add dependencies to gradle

  compile 'com.google.code.gson:gson:2.6.2'


First Activity

        Gson gson = new Gson();

        LinkedHashMap<String, String> map = new 
                                              LinkedHashMap<String, String>();
        map .put("Name", "Dhina");
        map .put("Blog", "Androiddhina");
        map .put("City", "Chennai");
        
        Intent intent = new Intent(activity, DetailsActivity.class);
        intent.putExtra("values",  map);
        startActivity(intent);


Second Activity

         LinkedHashMap<String, String> hashMap = new 
                                     LinkedHashMap<String, String>();

        String str = getIntent().getStringExtra("values");
        Gson gson = new Gson();
        Type entityType = new TypeToken
            <LinkedHashMap<String, String>>() {}.getType();
        hashMap = gson.fromJson(strentityType);


Happy coding :)