我有一个问题,我尝试了很多解决方案而且没有解决问题
这是日志
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<table>
<tr>
<th>
Product Detail Display
</th>
</tr>
<tr>
<td> ----- Product A -----</td>
</tr>
<tr>
<td> ----- Product B ----- </td>
</tr>
<tr>
<td> ----- Product C ----- </td>
</tr>
<tr>
<td> ----- Product D ----- </td>
</tr>
<tr>
<td>
<div class="left">Total: 4 Product(s)</div>
<div class="right"><button data-less="View Less Products" data-more="View More Products">View More Products</button></div>
</td>
</tr>
</table>
这是我的代码
06-17 21:59:20.412 11222-11222/com.alkhulaqi.ablularhman.counter D/AbsListView: unregisterIRListener() is called
06-17 21:59:20.432 11222-11222/com.alkhulaqi.ablularhman.counter I/MainActivity: connectAPIClient().
06-17 21:59:20.862 11222-11222/com.alkhulaqi.ablularhman.counter D/AbsListView: onVisibilityChanged() is called, visibility : 4
06-17 21:59:20.862 11222-11222/com.alkhulaqi.ablularhman.counter D/AbsListView: unregisterIRListener() is called
06-17 21:59:22.352 11222-11222/com.alkhulaqi.ablularhman.counter I/MainActivity: GoogleApiClient connection failed: ConnectionResult{statusCode=INTERNAL_ERROR, resolution=null, message=null}
06-17 21:59:22.352 11222-11222/com.alkhulaqi.ablularhman.counter I/dalvikvm: Could not find method android.app.Notification$Builder.setLocalOnly, referenced from method com.google.android.gms.common.GooglePlayServicesUtil.zza
06-17 21:59:22.352 11222-11222/com.alkhulaqi.ablularhman.counter W/dalvikvm: VFY: unable to resolve virtual method 475: Landroid/app/Notification$Builder;.setLocalOnly (Z)Landroid/app/Notification$Builder;
06-17 21:59:22.352 11222-11222/com.alkhulaqi.ablularhman.counter D/dalvikvm: VFY: replacing opcode 0x6e at 0x00cb
06-17 21:59:22.352 11222-11222/com.alkhulaqi.ablularhman.counter E/GoogleApiAvailability: Internal error occurred. Please see logs for detailed information
这是我的傻瓜
package com.alkhulaqi.ablularhman.counter;
import android.graphics.Color;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import android.app.Activity;
import android.content.Intent;
import android.content.IntentSender;
import android.content.IntentSender.SendIntentException;
import android.graphics.Bitmap;
import android.provider.MediaStore;
import android.util.Log;
import android.view.View;
import android.widget.TextView;
import com.google.android.gms.common.ConnectionResult;
import com.google.android.gms.common.GoogleApiAvailability;
import com.google.android.gms.common.api.GoogleApiClient;
import com.google.android.gms.common.api.GoogleApiClient.ConnectionCallbacks;
import com.google.android.gms.common.api.GoogleApiClient.OnConnectionFailedListener;
import com.google.android.gms.common.api.ResultCallback;
import com.google.android.gms.drive.Drive;
import com.google.android.gms.drive.DriveApi.DriveContentsResult;
import com.google.android.gms.drive.MetadataChangeSet;
/*** REMEMBER TO ENABLE Google Drive API
* https://console.developers.google.com
* you can contact me to get a client_id.json or Client ID for testing @ jorgesys12@gmail.com
*/
public class GoogleDriveActivity extends AppCompatActivity implements ConnectionCallbacks,
OnConnectionFailedListener {
private static final String TAG = "MainActivity";
private static final int REQUEST_CODE_CAPTURE_IMAGE = 1;
private static final int REQUEST_CODE_CREATOR = 2;
private static final int REQUEST_CODE_RESOLUTION = 3;
private boolean isAPÏConnected;
private GoogleApiClient mGoogleApiClient;
private Bitmap mBitmapToSave;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_google_drive);
//Initialize Google Drive API Client!
connectAPIClient();
findViewById(R.id.btnTakePhoto).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
//Start camera to take a picture
if(isAPÏConnected) {
startActivityForResult(new Intent(MediaStore.ACTION_IMAGE_CAPTURE), REQUEST_CODE_CAPTURE_IMAGE);
}
else
{
Snackbar snackbar = Snackbar.make(findViewById(android.R.id.content)
, "Error Google API is disable or permissions are required!"
, Snackbar.LENGTH_LONG)
. setActionTextColor(Color.RED);
View snackbarView = snackbar.getView();
snackbarView.setBackgroundColor(Color.DKGRAY);
TextView textView = (TextView) snackbarView.findViewById(android.support.design.R.id.snackbar_text);
textView.setTextColor(Color.RED);
snackbar.show();
}
}
});
}
//Create a new file and save it to Drive.
private void saveFileToDrive() {
// Start by creating a new contents, and setting a callback.
Log.i(TAG, "saveFileToDrive() Creating new content.");
final Bitmap image = mBitmapToSave;
Drive.DriveApi.newDriveContents(mGoogleApiClient).setResultCallback(new ResultCallback<DriveContentsResult>() {
@Override
public void onResult(DriveContentsResult result) {
// If the operation wasn't successful, return
if (!result.getStatus().isSuccess()) {
Log.e(TAG, "Failed to create new content!.");
return;
}
Log.i(TAG, "New content has been created.");
// Get an output stream for the contents.
OutputStream outputStream = result.getDriveContents().getOutputStream();
// Write the bitmap data from it.
ByteArrayOutputStream bitmapStream = new ByteArrayOutputStream();
image.compress(Bitmap.CompressFormat.PNG, 100, bitmapStream);
try {
outputStream.write(bitmapStream.toByteArray());
} catch (IOException e1) {
Log.i(TAG, "Unable to write file contents.");
}
// Create the initial metadata - MIME type and title.
// Note that the user will be able to change the title later.
MetadataChangeSet metadataChangeSet = new MetadataChangeSet.Builder()
.setMimeType("image/jpeg").setTitle("myPhoto.png").build();
// Create an intent for the file chooser, and start it.
IntentSender intentSender = Drive.DriveApi
.newCreateFileActivityBuilder()
.setInitialMetadata(metadataChangeSet)
.setInitialDriveContents(result.getDriveContents())
.build(mGoogleApiClient);
try {
startIntentSenderForResult(
intentSender, REQUEST_CODE_CREATOR, null, 0, 0, 0);
} catch (SendIntentException e) {
Log.i(TAG, "Failed to launch file chooser.");
}
}
});
}
@Override
protected void onStart() {
super.onStart();
if (mGoogleApiClient == null) {
// Create the API client and bind it to an instance variable.
// We use this instance as the callback for connection and connection
// failures.
// Since no account name is passed, the user is prompted to choose.
mGoogleApiClient = new GoogleApiClient.Builder(this)
.addApi(Drive.API)
.addScope(Drive.SCOPE_FILE)
.addConnectionCallbacks(this)
.addOnConnectionFailedListener(this)
.build();
}
// Connect the client.
mGoogleApiClient.connect();
}
//Disconnect only when the application is closed!
@Override
protected void onStop() {
if (mGoogleApiClient != null) {
mGoogleApiClient.disconnect();
}
super.onStop();
}
@Override
protected void onDestroy() {
if (mGoogleApiClient != null) {
mGoogleApiClient.disconnect();
}
super.onDestroy();
}
@Override
protected void onActivityResult(final int requestCode, final int resultCode, final Intent data) {
switch (requestCode) {
case REQUEST_CODE_CAPTURE_IMAGE:
// Called after a photo has been taken.
if (resultCode == Activity.RESULT_OK) {
// Store the image data as a bitmap for writing later.
mBitmapToSave = (Bitmap) data.getExtras().get("data");
saveFileToDrive();
}
break;
case REQUEST_CODE_CREATOR:
//Called after a file is saved to Drive.
if (resultCode == RESULT_OK) { //succesfully saved!.
Log.i(TAG, "Image successfully saved.");
mBitmapToSave = null;
Snackbar snackbar = Snackbar.make(findViewById(android.R.id.content), "Photo succesfully saved to Google Drive!", Snackbar.LENGTH_LONG)
.setActionTextColor(Color.RED);
View snackbarView = snackbar.getView();
snackbarView.setBackgroundColor(Color.DKGRAY);
TextView textView = (TextView) snackbarView.findViewById(android.support.design.R.id.snackbar_text);
textView.setTextColor(Color.YELLOW);
snackbar.show();
}
break;
}
}
@Override
public void onConnectionFailed(ConnectionResult result) {
Log.i(TAG, "GoogleApiClient connection failed: " + result.toString());
isAPÏConnected = false;
if (!result.hasResolution()) {
// show the localized error dialog.
GoogleApiAvailability.getInstance().getErrorDialog(this, result.getErrorCode(), 0).show();
return;
}
// Called typically when the app is not yet authorized, and authorization dialog is displayed to the user.
try {
result.startResolutionForResult(this, REQUEST_CODE_RESOLUTION);
} catch (SendIntentException e) {
Log.e(TAG, "Exception while starting resolution activity. " + e.getMessage());
}
}
@Override
public void onConnected(Bundle connectionHint) {
Log.i(TAG, "* API client connected !!!.");
isAPÏConnected = true;
}
@Override
public void onConnectionSuspended(int cause) {
Log.i(TAG, "GoogleApiClient connection suspended.");
}
private void connectAPIClient(){
if (mGoogleApiClient == null) {
Log.i(TAG, "connectAPIClient().");
// Create the API client and bind it to an instance variable.
// We use this instance as the callback for connection and connection
// failures.
// Since no account name is passed, the user is prompted to choose.
mGoogleApiClient = new GoogleApiClient.Builder(this)
.addApi(Drive.API)
.addScope(Drive.SCOPE_FILE)
.addConnectionCallbacks(this)
.addOnConnectionFailedListener(this)
.build();
}
// Connect the client. Once connected, the camera is launched.
mGoogleApiClient.connect();
}
}
这是我的manifest.xml文件
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
testCompile 'junit:junit:4.12'
compile 'com.android.support:appcompat-v7:23.4.0'
compile 'com.android.support:design:23.4.0'
compile 'com.android.support:support-v4:23.4.0'
// compile 'com.google.android.gms:play-services-auth:8.4.0'
// compile 'com.google.android.gms:play-services:8.4.0'
compile 'com.google.android.gms:play-services-drive:8.4.0'
compile 'pub.devrel:easypermissions:0.2.1'
compile('com.google.api-client:google-api-client-android:1.22.0') {
exclude group: 'org.apache.httpcomponents'
}
compile('com.google.apis:google-api-services-drive:v3-rev76-1.22.0') {
exclude group: 'org.apache.httpcomponents'
}
编辑1: 我已启用Drive API并创建API密钥(放置类型Android,设置包,设置SHA1)我在谷歌开发者控制台的文档中看到这一点。复制密钥的ID,并将其显示在元数据标记中。
错误仍然存在。