J'utilise la méthode DisplayDialog ... Ça marche mais Eclipse me montre un avertissement sur ceci: Méthode: P> public class Home extends Activity {
private static final String BASE64_PUBLIC_KEY = "mykeywithoutspaces";
// Generate your own 20 random bytes, and put them here.
private static final byte[] SALT = new byte[] {
-00, 00, 30, -2, -58, -57, 00, -64, 51, 32, -95, -45, 13, -6, -36, -15, -11, 32, -64,
89
};
private TextView mStatusText;
private Button mCheckLicenseButton;
private LicenseCheckerCallback mLicenseCheckerCallback;
private LicenseChecker mChecker;
// A handler on the UI thread.
private Handler mHandler;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS);
setContentView(R.layout.main);
mStatusText = (TextView) findViewById(R.id.status_text);
buttonNewDoc = (ImageButton) findViewById(R.id.btNewDoc);
buttonNewDoc.setOnClickListener(mNewDoc);
mCheckLicenseButton = (Button) findViewById(R.id.check_license_button);
mCheckLicenseButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View view) {
doCheck();
}
});
mHandler = new Handler();
// Try to use more data here. ANDROID_ID is a single point of attack.
String deviceId = Secure.getString(getContentResolver(), Secure.ANDROID_ID);
// Library calls this when it's done.
mLicenseCheckerCallback = new MyLicenseCheckerCallback();
// Construct the LicenseChecker with a policy.
mChecker = new LicenseChecker(
this, new ServerManagedPolicy(this,
new AESObfuscator(SALT, getPackageName(), deviceId)),
BASE64_PUBLIC_KEY);
doCheck();
}
protected Dialog onCreateDialog(int id) {
final boolean bRetry = id == 1;
return new AlertDialog.Builder(this)
.setTitle(R.string.unlicensed_dialog_title)
.setMessage(bRetry ? R.string.unlicensed_dialog_retry_body : R.string.unlicensed_dialog_body)
.setPositiveButton(bRetry ? R.string.retry_button : R.string.buy_button, new DialogInterface.OnClickListener() {
boolean mRetry = bRetry;
public void onClick(DialogInterface dialog, int which) {
if ( mRetry ) {
doCheck();
} else {
Intent marketIntent = new Intent(Intent.ACTION_VIEW, Uri.parse(
"http://market.android.com/details?id=" + getPackageName()));
startActivity(marketIntent);
}
}
})
.setNegativeButton(R.string.quit_button, new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
finish();
}
}).create();
}
private void doCheck() {
buttonNewDoc.setEnabled(false);
mCheckLicenseButton.setEnabled(false);
setProgressBarIndeterminateVisibility(true);
mStatusText.setText(R.string.checking_license);
mChecker.checkAccess(mLicenseCheckerCallback);
}
private void displayResult(final String result) {
mHandler.post(new Runnable() {
public void run() {
mStatusText.setText(result);
setProgressBarIndeterminateVisibility(false);
mCheckLicenseButton.setEnabled(true);
}
});
}
private void displayDialog(final boolean showRetry) {
mHandler.post(new Runnable() {
public void run() {
setProgressBarIndeterminateVisibility(false);
showDialog(showRetry ? 1 : 0);
}
});
}
private class MyLicenseCheckerCallback implements LicenseCheckerCallback {
public void allow(int policyReason) {
if (isFinishing()) {
// Don't update UI if Activity is finishing.
return;
}
// Should allow user access.
displayResult(getString(R.string.allow));
buttonNewDoc.setEnabled(false);
}
public void dontAllow(int policyReason) {
if (isFinishing()) {
// Don't update UI if Activity is finishing.
return;
}
displayResult(getString(R.string.dont_allow));
// Should not allow access. In most cases, the app should assume
// the user has access unless it encounters this. If it does,
// the app should inform the user of their unlicensed ways
// and then either shut down the app or limit the user to a
// restricted set of features.
// In this example, we show a dialog that takes the user to Market.
// If the reason for the lack of license is that the service is
// unavailable or there is another problem, we display a
// retry button on the dialog and a different message.
displayDialog(policyReason == Policy.RETRY);
}
public void applicationError(int errorCode) {
if (isFinishing()) {
// Don't update UI if Activity is finishing.
return;
}
String result = String.format(getString(R.string.application_error), errorCode);
displayResult(result);
}
}
@Override
protected void onDestroy() {
super.onDestroy();
mChecker.onDestroy();
}
}
4 Réponses :
Votre activité doit sous-classement voici une vue d'ensemble: http://androïde-developers.blogspot.com/2012/05/USTION-DialogFraGments.html P> P> fragmentactivité code>, qui peut être trouvé dans Bibliothèque de support V4 , que vous devriez ajouter à votre projet. Vous pouvez alors obtenir une référence à la
fragmentmanager code> à l'aide de
getupportfragmentManager () code> Pour afficher un
Dialogmentfragment code>. Vous devrez créer une classe code> de boîte de dialogue code> avec la mise en page et la logique que votre boîte de dialogue nécessite. Voici comment vous le montreriez de votre
fragmentactivité code>:
Merci d'avoir répondu. Cependant, j'ai du mal à faire correctement ces tâches dans ma classe ... Pourriez-vous écrire plus de code? Merci.
Avez-vous vu le lien vers le blog Android? C'est un guide étape par étape assez complet avec tout le code que vous pourriez avoir besoin ...
Qu'est-ce que Google semble utiliser dans cet exemple consiste à modifier "la boîte de dialogue protégée surCreateDialog (int ID) {" afin qu'elle soit appelée en interne toujours appelée "showredialog (showretry? 1: 0);" Création de la boîte de dialogue par défaut pour Réessayer / Annuler.
Je suggère d'utiliser le code suivant, créant une méthode pratique qui crée la boîte de dialogue standard et la modification ou la suppression du "OncreateAnog ()" car cela devient inutile. P>
protected Dialog onCreateDialog(int id) { return CreateDialogRetryCancel(id); } public Dialog CreateDialogRetryCancel(int id) { final boolean bRetry = id == 1; return new AlertDialog.Builder(this) .setTitle(R.string.unlicensed_dialog_title) .setMessage(bRetry ? R.string.unlicensed_dialog_retry_body : R.string.unlicensed_dialog_body) .setPositiveButton(bRetry ? R.string.retry_button : R.string.buy_button, new DialogInterface.OnClickListener() { boolean mRetry = bRetry; public void onClick(DialogInterface dialog, int which) { if ( mRetry ) { doCheck(); } else { Intent marketIntent = new Intent(Intent.ACTION_VIEW, Uri.parse( "http://market.android.com/details?id=" + getPackageName())); startActivity(marketIntent); } } }) .setNegativeButton(R.string.quit_button, new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog, int which) { finish(); } }).create(); } private void displayDialog(final boolean showRetry) { mHandler.post(new Runnable() { public void run() { setProgressBarIndeterminateVisibility(false); CreateDialogRetryCancel(showRetry ? 1 : 0).show(); //showDialog(showRetry ? 1 : 0); mCheckLicenseButton.setEnabled(true); } }); }
FragmentManager fm = getSupportFragmentManager(); yourDialog.show(fm, "some_optional_tag"); The getSupportFragmentManager() was accepted only when the correct class is imported while making DialogFragment i.e import android.support.v4.app.DialogFragment
kotlin:
Problème résolu après la conversion à Kotlin de Java.