En esta guía para desarrolladores se describe cómo usar la versión 4 del SDK de Google Analytics para Android para medir eventos en la aplicación.
Descripción general
Los eventos son una forma útil de recopilar datos sobre la interacción de un usuario con componentes interactivos de tu aplicación, como la pulsación de un botón o el uso de un elemento determinado en un juego.
Un evento consta de cuatro campos que puedes usar para describir la interacción de un usuario con el contenido de tu aplicación:
Nombre del campo
Tipo
Obligatorio
Descripción
Category
String
Sí
Categoría del evento
Action
String
Sí
Acción del evento
Label
String
No
Etiqueta del evento
Value
Long
No
Valor del evento
Implementación
Para enviar un evento a Google Analytics, usa HitBuilders.EventBuilder
y envía el hit, tal como se muestra en el siguiente ejemplo:
// Get tracker.
Tracker t = ((AnalyticsSampleApp) getActivity().getApplication()).getTracker(
TrackerName.APP_TRACKER);
// Build and send an Event.
t.send(new HitBuilders.EventBuilder()
.setCategory(getString(categoryId))
.setAction(getString(actionId))
.setLabel(getString(labelId))
.build());
Consulta la sección Configuración avanzada para obtener información detallada sobre el método getTracker.
Si quieres obtener más información sobre los hits sin interacción y saber cuándo puedes usarlos, consulta la sección Eventos sin interacción en el Centro de Ayuda de Google Analytics.
Consultar un fragmento de código desde la aplicación de ejemplo
El siguiente fragmento de código muestra un ejemplo de Fragment que envía un evento:
package com.google.android.apps.mobileplayground;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.Button;
import com.google.android.apps.mobileplayground.AnalyticsSampleApp.TrackerName;
import com.google.android.gms.analytics.GoogleAnalytics;
import com.google.android.gms.analytics.HitBuilders;
import com.google.android.gms.analytics.Tracker;
/**
* Class to exercise Event hits.
*/
public class EventFragment extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
View view = inflater.inflate(R.layout.event, container, false);
setupEvent(view, R.id.video1Play, R.string.videoCategory, R.string.videoPlay, R.string.video1);
setupEvent(view, R.id.video1Pause, R.string.videoCategory, R.string.videoPause,
R.string.video1);
setupEvent(view, R.id.video2Play, R.string.videoCategory, R.string.videoPlay, R.string.video2);
setupEvent(view, R.id.video2Pause, R.string.videoCategory, R.string.videoPause,
R.string.video2);
setupEvent(view, R.id.book1View, R.string.bookCategory, R.string.bookView, R.string.book1);
setupEvent(view, R.id.book1Share, R.string.bookCategory, R.string.bookShare, R.string.book1);
final Button dispatchButton = (Button) view.findViewById(R.id.eventDispatch);
dispatchButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// Manually start a dispatch (Unnecessary if the tracker has a dispatch interval)
GoogleAnalytics.getInstance(getActivity().getApplicationContext()).dispatchLocalHits();
}
});
return view;
}
private void setupEvent(View v, int buttonId, final int categoryId, final int actionId,
final int labelId) {
final Button pageviewButton = (Button) v.findViewById(buttonId);
pageviewButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// Get tracker.
Tracker t = ((AnalyticsSampleApp) getActivity().getApplication()).getTracker(
TrackerName.APP_TRACKER);
// Build and send an Event.
t.send(new HitBuilders.EventBuilder()
.setCategory(getString(categoryId))
.setAction(getString(actionId))
.setLabel(getString(labelId))
.build());
}
});
}
}