2016-10-10 155 views
0

我試圖獲取當前位置的經度和緯度並將其保存在Firebase數據庫中。源代碼工作正常,但經度和緯度保存爲0.0位置(經度,緯度)返回0

this is how it looks like in the database.

我該如何解決這個問題,並得到正確的當前位置?不介意幾十個輸入類,我還沒有移除任何東西。

如果這是一個重複的問題,我真的很抱歉。

public class Register extends AppCompatActivity implements View.OnClickListener, GoogleApiClient.ConnectionCallbacks, GoogleApiClient.OnConnectionFailedListener { 
    EditText edtemail, edtpass, edtnumber; 
    Button btnRegister, btnLogin, forgotpwdbtn; 
    private FirebaseAuth auth; 
    private DatabaseReference mDatabase; 


    private GoogleApiClient googleApiClient; 
    private Location location; 
    private double longitude; 
    private double latitude; 
    String mUserId; 


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


     btnRegister = (Button) findViewById(R.id.btnRegister); 
     btnLogin = (Button) findViewById(R.id.btnLogin); 
     forgotpwdbtn = (Button) findViewById(R.id.forgotpwdbtn); 

     btnRegister.setOnClickListener(this); 
     btnLogin.setOnClickListener(this); 
     forgotpwdbtn.setOnClickListener(this); 
     auth = FirebaseAuth.getInstance(); 


     mDatabase = FirebaseDatabase.getInstance().getReference(); 
     mUserId = FirebaseAuth.getInstance().getCurrentUser().getUid(); 

     edtemail = (EditText) findViewById(R.id.edtemail); 
     edtpass = (EditText) findViewById(R.id.edtpass); 
     edtnumber = (EditText) findViewById(R.id.edtnumber); 


    } 


    public void onClick(View view) { 

     switch (view.getId()) { 

      case R.id.forgotpwdbtn: 
       Intent passwordIntent = new Intent(Register.this, ForgotPasswordActivity.class); 
       startActivity(passwordIntent); 
       break; 
      case R.id.btnLogin: 
       Intent intent = new Intent(Register.this, LoginActivity.class); 
       startActivity(intent); 
       break; 
      case R.id.btnRegister: 
       googleApiClient = new GoogleApiClient.Builder(this) 
         .addConnectionCallbacks(this) 
         .addOnConnectionFailedListener(this) 
         .addApi(LocationServices.API) 
         .build(); 

       final String key = mDatabase.child("data").push().getKey(); 
       final String email = edtemail.getText().toString().trim(); 
       final String password = edtpass.getText().toString().trim(); 
       final String number = edtnumber.getText().toString().trim(); 
       if (ActivityCompat.checkSelfPermission(this, android.Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(this, android.Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) { 
        // TODO: Consider calling 
        // ActivityCompat#requestPermissions 
        // here to request the missing permissions, and then overriding 
        // public void onRequestPermissionsResult(int requestCode, String[] permissions, 
        //           int[] grantResults) 
        // to handle the case where the user grants the permission. See the documentation 
        // for ActivityCompat#requestPermissions for more details. 
        return; 
       } 
       location = LocationServices.FusedLocationApi.getLastLocation(googleApiClient); 
       if (location != null) { 
        //Getting longitude and latitude 
        longitude = location.getLongitude(); 
        latitude = location.getLatitude(); 
       } 

       String lon = String.valueOf(longitude); 
       String lat = String.valueOf(latitude); 

       Item newItem = new Item(email, password, number, lon, lat); 
       Map<String, Object> itemValues = newItem.toMap(); 
       Map<String, Object> childUpdates = new HashMap<>(); 
       childUpdates.put("/data/" + mUserId + "/" + key, itemValues); 
       mDatabase.updateChildren(childUpdates); 

        auth.createUserWithEmailAndPassword(email, password).addOnCompleteListener(Register.this, new OnCompleteListener<AuthResult>() { 


         @Override 
         public void onComplete(@NonNull Task<AuthResult> task) { 

          if (task.isSuccessful()) { 

           Toast.makeText(Register.this, "Registration success", Toast.LENGTH_SHORT).show(); 
           Intent intent = new Intent(Register.this, LoginActivity.class); 
           startActivity(intent); 

          } else { 
           Toast.makeText(Register.this, "Registration failed." + task.getException(), Toast.LENGTH_SHORT).show(); 
          } 
         } 
        }); 
        break; 
       } 
     } 

    @Override 
    public void onConnected(@Nullable Bundle bundle) { 

    } 

    @Override 
    public void onConnectionSuspended(int i) { 

    } 

    @Override 
    public void onConnectionFailed(@NonNull ConnectionResult connectionResult) { 

    } 
} 

回答

1

您沒有連接到GoogleApiClient。使用onCreate方法創建GoogleApiClient對象。重寫另外兩種方法,onStartonStop。在onStart方法中,通過調用googleapiclient.connect()連接到GoogleApiClient。在onStop方法中,通過調用if(googleapiclient.isConnected()) { googleapiclient.disconnect() }斷開客戶端連接。

+0

我照你說的做了,但是當我按下注冊按鈕時發生了新的錯誤。 「java.lang.NullPointerException:試圖調用空對象引用」void com.google.android.gms.common.api.GoogleApiClient.connect()' –

+0

您是否已將「googleApiClient = new GoogleApiClient.Builder (this).addConnectionCallbacks(this).addOnConnectionFailedListener(this).addApi(LocationServices.API).build();'代碼到'onCreate'方法?? –

+0

是的,我仍然一樣。按下注冊按鈕後停止。 –