it-roy-ru.com

Как открыть Google Play Store прямо из моего приложения для Android?

Я открыл Google Play Store, используя следующий код 

Intent i = new Intent(Android.content.Intent.ACTION_VIEW);
i.setData(Uri.parse("https://play.google.com/store/apps/details?id=my packagename "));
startActivity(i);.

Но он показывает мне полный вид действия как выбрать опцию (браузер/Play Store). Мне нужно открыть приложение в Play Store напрямую.

473
Rajesh Kumar

Вы можете сделать это, используя префикс market:// .

final String appPackageName = getPackageName(); // getPackageName() from Context or Activity object
try {
    startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse("market://details?id=" + appPackageName)));
} catch (Android.content.ActivityNotFoundException anfe) {
    startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse("https://play.google.com/store/apps/details?id=" + appPackageName)));
}

Мы используем блок try/catch здесь, потому что Exception будет брошен, если Play Store не установлен на целевом устройстве.

NOTE: любое приложение может зарегистрироваться как способное обрабатывать URI market://details?id=<appId>, если вы хотите специально настроить таргетинг на Google Play, проверьте ответ Berťák

1268
Eric

Многие ответы здесь предлагают использоватьUri.parse("market://details?id=" + appPackageName))для открытия Google Play, но я думаю, что этого недостаточно на самом деле: 

Некоторые сторонние приложения могут использовать свои собственные фильтры намерений с определенной схемой "market://", поэтому они могут обрабатывать предоставленный Uri вместо Google Play (я сталкивался с такой ситуацией, например, в приложении SnapPea). Вопрос «Как открыть Google Play Store?», Поэтому я предполагаю, что вы не хотите открывать какие-либо другие приложения. Пожалуйста, обратите внимание, что, например, рейтинг приложения актуален только в приложении GP Store и т. д.

Чтобы открыть Google Play И ТОЛЬКО Google Play, я использую этот метод:

public static void openAppRating(Context context) {
    // you can also use BuildConfig.APPLICATION_ID
    String appId = context.getPackageName();
    Intent rateIntent = new Intent(Intent.ACTION_VIEW,
        Uri.parse("market://details?id=" + appId));
    boolean marketFound = false;

    // find all applications able to handle our rateIntent
    final List<ResolveInfo> otherApps = context.getPackageManager()
        .queryIntentActivities(rateIntent, 0);
    for (ResolveInfo otherApp: otherApps) {
        // look for Google Play application
        if (otherApp.activityInfo.applicationInfo.packageName
                .equals("com.Android.vending")) {

            ActivityInfo otherAppActivity = otherApp.activityInfo;
            ComponentName componentName = new ComponentName(
                    otherAppActivity.applicationInfo.packageName,
                    otherAppActivity.name
                    );
            // make sure it does NOT open in the stack of your activity
            rateIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
            // task reparenting if needed
            rateIntent.addFlags(Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED);
            // if the Google Play was already open in a search result
            //  this make sure it still go to the app page you requested
            rateIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
            // this make sure only the Google Play app is allowed to
            // intercept the intent
            rateIntent.setComponent(componentName);
            context.startActivity(rateIntent);
            marketFound = true;
            break;

        }
    }

    // if GP not present on device, open web browser
    if (!marketFound) {
        Intent webIntent = new Intent(Intent.ACTION_VIEW,
            Uri.parse("https://play.google.com/store/apps/details?id="+appId));
        context.startActivity(webIntent);
    }
}

Дело в том, что когда наше приложение может открыть больше приложений, кроме Google Play, диалоговое окно выбора приложения пропускается и приложение GP запускается напрямую.

UPDATE: Иногда кажется, что он открывает только приложение GP, не открывая профиль приложения. Как предложил TrevorWiley в своем комментарии, Intent.FLAG_ACTIVITY_CLEAR_TOP может решить эту проблему. (Я сам еще не проверял ...)

Смотрите этот ответ для понимания того, что делает Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED.

139
Berťák

Перейдите по официальной ссылке Android Developer в качестве учебного пособия. Шаг за шагом посмотрите и получите код для вашего пакета приложений из Play Store, если он существует или приложений Play Store не существует, затем откройте приложение из веб-браузера.

Официальная ссылка разработчика Android

http://developer.Android.com/distribute/tools/promote/linking.html

Ссылка на страницу приложения

С веб-сайта: http://play.google.com/store/apps/details?id=<package_name>

Из приложения для Android: market://details?id=<package_name>

Ссылка на список товаров

С веб-сайта: http://play.google.com/store/search?q=pub:<publisher_name>

Из приложения для Android: market://search?q=pub:<publisher_name>

Ссылка на результат поиска

С веб-сайта: http://play.google.com/store/search?q=<search_query>&c=apps

Из приложения для Android: market://search?q=<seach_query>&c=apps

64
Najib Puthawala

попробуй это

Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setData(Uri.parse("market://details?id=com.example.Android"));
startActivity(intent);
22
Youddh

Все приведенные выше ответы открывают Google Play в новом представлении того же приложения, если вы действительно хотите открыть Google Play (или любое другое приложение) независимо:

Intent launchIntent = getPackageManager().getLaunchIntentForPackage("com.Android.vending");

// package name and activity
ComponentName comp = new ComponentName("com.Android.vending",
                                       "com.google.Android.finsky.activities.LaunchUrlHandlerActivity"); 
launchIntent.setComponent(comp);

// sample to open facebook app
launchIntent.setData(Uri.parse("market://details?id=com.facebook.katana"));
startActivity(launchIntent);

Важной частью является то, что на самом деле открывает Google Play или любое другое приложение независимо.  

Большая часть того, что я видел, использует подход других ответов, и это было не то, что мне нужно, надеюсь, это кому-нибудь поможет.

С уважением. 

18
Jonathan Caballero

Вы можете проверить, установлено ли приложение Google Play Store , и, если это так, вы можете использовать протокол "market: //" .

final String my_package_name = "........."  // <- HERE YOUR PACKAGE NAME!!
String url = "";

try {
    //Check whether Google Play Store is installed or not:
    this.getPackageManager().getPackageInfo("com.Android.vending", 0);

    url = "market://details?id=" + my_package_name;
} catch ( final Exception e ) {
    url = "https://play.google.com/store/apps/details?id=" + my_package_name;
}


//Open the app page in Google Play Store:
final Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url));
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_WHEN_TASK_RESET);
startActivity(intent);
12
Paolo Rovelli

использовать рынок: //

Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse("market://details?id=" + my_packagename));
10
Johannes Staehlin

В то время как ответ Эрика правильный, и код Берняка тоже работает. Я думаю, что это сочетает в себе оба более элегантно.

try {
    Intent appStoreIntent = new Intent(Intent.ACTION_VIEW, Uri.parse("market://details?id=" + appPackageName));
    appStoreIntent.setPackage("com.Android.vending");

    startActivity(appStoreIntent);
} catch (Android.content.ActivityNotFoundException exception) {
    startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse("https://play.google.com/store/apps/details?id=" + appPackageName)));
}

Используя setPackage, вы заставляете устройство использовать Play Store. Если не установлен Play Store, Exception будет пойман.

9
M3-n50

Ты можешь сделать:

final Uri marketUri = Uri.parse("market://details?id=" + packageName);
startActivity(new Intent(Intent.ACTION_VIEW, marketUri));

получить ссылку здесь :

Вы также можете попробовать подход, описанный в принятом ответе на этот вопрос: Не удается определить, установлен ли Google Play Store на устройстве Android

6
almalkawi

Готовое решение:

public class GoogleServicesUtils {

    public static void openAppInGooglePlay(Context context) {
        final String appPackageName = context.getPackageName();
        try {
            context.startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse("market://details?id=" + appPackageName)));
        } catch (Android.content.ActivityNotFoundException e) { // if there is no Google Play on device
            context.startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse("https://play.google.com/store/apps/details?id=" + appPackageName)));
        }
    }

}

На основании ответа Эрика.

4
Alexandr

Очень поздно в партии Официальные документы здесь. И код описан

Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setData(Uri.parse(
    "https://play.google.com/store/apps/details?id=com.example.Android"));
intent.setPackage("com.Android.vending");
startActivity(intent);

Когда вы настраиваете это намерение, передайте "com.Android.vending" в Intent.setPackage(), чтобы пользователи видели детали вашего приложения в приложение Google Play Store, а не в списке выбора . Для KOTLIN.

val intent = Intent(Intent.ACTION_VIEW).apply {
    data = Uri.parse(
            "https://play.google.com/store/apps/details?id=com.example.Android")
    setPackage("com.Android.vending")
}
startActivity(intent)

Если вы опубликовали мгновенное приложение с помощью Google Play Instant, вы можете запустить его следующим образом:

Intent intent = new Intent(Intent.ACTION_VIEW);
Uri.Builder uriBuilder = Uri.parse("https://play.google.com/store/apps/details")
    .buildUpon()
    .appendQueryParameter("id", "com.example.Android")
    .appendQueryParameter("launch", "true");

// Optional parameters, such as referrer, are passed onto the launched
// instant app. You can retrieve these parameters using
// Activity.getIntent().getData().
uriBuilder.appendQueryParameter("referrer", "exampleCampaignId");

intent.setData(uriBuilder.build());
intent.setPackage("com.Android.vending");
startActivity(intent);

Для КОТЛИНА

val uriBuilder = Uri.parse("https://play.google.com/store/apps/details")
        .buildUpon()
        .appendQueryParameter("id", "com.example.Android")
        .appendQueryParameter("launch", "true")

// Optional parameters, such as referrer, are passed onto the launched
// instant app. You can retrieve these parameters using Activity.intent.data.
uriBuilder.appendQueryParameter("referrer", "exampleCampaignId")

val intent = Intent(Intent.ACTION_VIEW).apply {
    data = uriBuilder.build()
    setPackage("com.Android.vending")
}
startActivity(intent)
3
Husnain Qasim

Если вы хотите открыть Google Play Store из своего приложения, используйте команду: market://details?gotohome=com.yourAppName, откроются страницы вашего приложения в Google Play Store.

Показать все приложения определенного издателя 

Поиск приложений, использующих запрос в заголовке или описании 

Ссылка: https://tricklio.com/market-details-gotohome-1/

1
Tahmid
public void launchPlayStore(Context context, String packageName) {
    Intent intent = null;
    try {
            intent = new Intent(Intent.ACTION_VIEW);
            intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
            intent.setData(Uri.parse("market://details?id=" + packageName));
            context.startActivity(intent);
        } catch (Android.content.ActivityNotFoundException anfe) {
            startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse("https://play.google.com/store/apps/details?id=" + packageName)));
        }
    }
1
Anonymous

Вот окончательный код из приведенных выше ответов, который сначала пытается открыть приложение с помощью приложения Google Play Store и, в частности, Play Store, в случае сбоя он запускает представление действия с помощью веб-версии: Credits to @Eric, @ Джонатан Кабальеро

public void goToPlayStore() {
        String playStoreMarketUrl = "market://details?id=";
        String playStoreWebUrl = "https://play.google.com/store/apps/details?id=";
        String packageName = getActivity().getPackageName();
        try {
            Intent intent =  getActivity()
                            .getPackageManager()
                            .getLaunchIntentForPackage("com.Android.vending");
            if (intent != null) {
                ComponentName androidComponent = new ComponentName("com.Android.vending",
                        "com.google.Android.finsky.activities.LaunchUrlHandlerActivity");
                intent.setComponent(androidComponent);
                intent.setData(Uri.parse(playStoreMarketUrl + packageName));
            } else {
                intent = new Intent(Intent.ACTION_VIEW, Uri.parse(playStoreMarketUrl + packageName));
            }
            startActivity(intent);
        } catch (ActivityNotFoundException e) {
            Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(playStoreWebUrl + packageName));
            startActivity(intent);
        }
    }
1
MoGa

Моя функция расширения kotlin для этой цели

fun Context.canPerformIntent(intent: Intent): Boolean {
        val mgr = this.packageManager
        val list = mgr.queryIntentActivities(intent, PackageManager.MATCH_DEFAULT_ONLY)
        return list.size > 0
    }

И в твоей деятельности

val uri = if (canPerformIntent(Intent(Intent.ACTION_VIEW, Uri.parse("market://")))) {
            Uri.parse("market://details?id=" + appPackageName)
        } else {
            Uri.parse("https://play.google.com/store/apps/details?id=" + appPackageName)
        }
        startActivity(Intent(Intent.ACTION_VIEW, uri))
1
Arpan Sarkar

Я объединил ответы Berťák и Stefano Munarini для создания гибридного решения, которое обрабатывает оба - Оценить это приложение и Показать больше приложений сценарий.

        /**
         * This method checks if GooglePlay is installed or not on the device and accordingly handle
         * Intents to view for rate App or Publisher's Profile
         *
         * @param showPublisherProfile pass true if you want to open Publisher Page else pass false to open APp page
         * @param publisherID          pass Dev ID if you have passed PublisherProfile true
         */
        public void openPlayStore(boolean showPublisherProfile, String publisherID) {

            //Error Handling
            if (publisherID == null || !publisherID.isEmpty()) {
                publisherID = "";
                //Log and continue
                Log.w("openPlayStore Method", "publisherID is invalid");
            }

            Intent openPlayStoreIntent;
            boolean isGooglePlayInstalled = false;

            if (showPublisherProfile) {
                //Open Publishers Profile on PlayStore
                openPlayStoreIntent = new Intent(Intent.ACTION_VIEW,
                        Uri.parse("market://search?q=pub:" + publisherID));
            } else {
                //Open this App on PlayStore
                openPlayStoreIntent = new Intent(Intent.ACTION_VIEW,
                        Uri.parse("market://details?id=" + getPackageName()));
            }

            // find all applications who can handle openPlayStoreIntent
            final List<ResolveInfo> otherApps = getPackageManager()
                    .queryIntentActivities(openPlayStoreIntent, 0);
            for (ResolveInfo otherApp : otherApps) {

                // look for Google Play application
                if (otherApp.activityInfo.applicationInfo.packageName.equals("com.Android.vending")) {

                    ActivityInfo otherAppActivity = otherApp.activityInfo;
                    ComponentName componentName = new ComponentName(
                            otherAppActivity.applicationInfo.packageName,
                            otherAppActivity.name
                    );
                    // make sure it does NOT open in the stack of your activity
                    openPlayStoreIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
                    // task reparenting if needed
                    openPlayStoreIntent.addFlags(Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED);
                    // if the Google Play was already open in a search result
                    //  this make sure it still go to the app page you requested
                    openPlayStoreIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
                    // this make sure only the Google Play app is allowed to
                    // intercept the intent
                    openPlayStoreIntent.setComponent(componentName);
                    startActivity(openPlayStoreIntent);
                    isGooglePlayInstalled = true;
                    break;

                }
            }
            // if Google Play is not Installed on the device, open web browser
            if (!isGooglePlayInstalled) {

                Intent webIntent;
                if (showPublisherProfile) {
                    //Open Publishers Profile on web browser
                    webIntent = new Intent(Intent.ACTION_VIEW,
                            Uri.parse("http://play.google.com/store/search?q=pub:" + getPackageName()));
                } else {
                    //Open this App on web browser
                    webIntent = new Intent(Intent.ACTION_VIEW,
                            Uri.parse("https://play.google.com/store/apps/details?id=" + getPackageName()));
                }
                startActivity(webIntent);
            }
        }

Использование

  • Чтобы открыть профиль издателей
   @OnClick(R.id.ll_more_apps)
        public void showMoreApps() {
            openPlayStore(true, "Hitesh Sahu");
        }
  • Открыть страницу приложения в PlayStore
@OnClick(R.id.ll_rate_this_app)
public void openAppInPlayStore() {
    openPlayStore(false, "");
}
0
Hitesh Sahu

Эта ссылка автоматически откроет приложение в market: // если вы работаете на Android и в браузере, если вы на ПК.

https://play.app.goo.gl/?link=https://play.google.com/store/apps/details?id=com.app.id&ddl=1&pcampaignid=web_ddl_1
0
Nikolay Shindarov

Котлинская версия с резервным и текущим синтаксисом

 fun openAppInPlayStore() {
    val uri = Uri.parse("market://details?id=" + context.packageName)
    val goToMarketIntent = Intent(Intent.ACTION_VIEW, uri)

    var flags = Intent.FLAG_ACTIVITY_NO_HISTORY or Intent.FLAG_ACTIVITY_MULTIPLE_TASK or Intent.FLAG_ACTIVITY_NEW_TASK
    flags = if (Build.VERSION.SDK_INT >= 21) {
        flags or Intent.FLAG_ACTIVITY_NEW_DOCUMENT
    } else {
        flags or Intent.FLAG_ACTIVITY_CLEAR_TASK
    }

    goToMarketIntent.addFlags(flags)

    try {
        startActivity(context, goToMarketIntent, null)
    } catch (e: ActivityNotFoundException) {
        val intent = Intent(Intent.ACTION_VIEW,
                Uri.parse("http://play.google.com/store/apps/details?id=" + context.packageName))

        startActivity(context, intent, null)
    }
}
0
kuzdu

Котлин

fun openAppInPlayStore(appPackageName: String) {
    try {
        startActivity(Intent(Intent.ACTION_VIEW, Uri.parse("market://details?id=$appPackageName")))
    } catch (exception: Android.content.ActivityNotFoundException) {
        startActivity(Intent(Intent.ACTION_VIEW, Uri.parse("https://play.google.com/store/apps/details?id=$appPackageName")))
    }
}
0
Khemraj

Люди, не забывайте, что вы могли бы получить что-то большее от этого. Я имею в виду, например, отслеживание UTM. https://developers.google.com/analytics/devguides/collection/Android/v4/campaigns

public static final String MODULE_ICON_PACK_FREE = "com.example.iconpack_free";
public static final String APP_STORE_URI =
        "market://details?id=%s&referrer=utm_source=%s&utm_medium=app&utm_campaign=plugin";
public static final String APP_STORE_GENERIC_URI =
        "https://play.google.com/store/apps/details?id=%s&referrer=utm_source=%s&utm_medium=app&utm_campaign=plugin";

try {
    startActivity(new Intent(
        Intent.ACTION_VIEW,
        Uri.parse(String.format(Locale.US,
            APP_STORE_URI,
            MODULE_ICON_PACK_FREE,
            getPackageName()))).addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP));
} catch (Android.content.ActivityNotFoundException anfe) {
    startActivity(new Intent(
        Intent.ACTION_VIEW,
        Uri.parse(String.format(Locale.US,
            APP_STORE_GENERIC_URI,
            MODULE_ICON_PACK_FREE,
            getPackageName()))).addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP));
}
0
Alex