Wayback Machinekoobas.hobune.stream
May JUN Jul
Previous capture 12 Next capture
2021 2022 2023
1 capture
12 Jun 22 - 12 Jun 22
sparklines
Close Help
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
  • Asset Store
  • Get Unity

UNITY ACCOUNT

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account
  • Blog
  • Forums
  • Answers
  • Evangelists
  • User Groups
  • Beta Program
  • Advisory Panel

Navigation

  • Home
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
    • Blog
    • Forums
    • Answers
    • Evangelists
    • User Groups
    • Beta Program
    • Advisory Panel

Unity account

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account

Language

  • Chinese
  • Spanish
  • Japanese
  • Korean
  • Portuguese
  • Ask a question
  • Spaces
    • Default
    • Help Room
    • META
    • Moderators
    • Topics
    • Questions
    • Users
    • Badges
  • Home /
  • Help Room /
avatar image
0
Question by loriarty · Jul 26, 2017 at 02:17 PM · gameobjectnull reference exceptionin app purchase

Hi there i need a little help please with in app purchase script

when the player purchase non consumable item at the end of the script i activate a game object to complete the process but it's always give me this message "MissingReferenceException: The object of type 'GameObject' has been destroyed but you are still trying to access it. Your script should either check if it is null or you should not destroy the object." and here's the script i hope you can help me because i'm really new to scripting

 using System;
 using System.Collections.Generic;
 using UnityEngine;
 using UnityEngine.Purchasing;
 
 // Placing the Purchaser class in the CompleteProject namespace allows it to interact with ScoreManager, 
 // one of the existing Survival Shooter scripts.
 namespace CompleteProject
 {
         // Deriving the Purchaser class from IStoreListener enables it to receive messages from Unity Purchasing.
         public class Purchaser : MonoBehaviour, IStoreListener
         {
                 private static IStoreController m_StoreController;          // The Unity Purchasing system.
                 private static IExtensionProvider m_StoreExtensionProvider; // The store-specific Purchasing subsystems.
 
                 // Product identifiers for all products capable of being purchased: 
                 // "convenience" general identifiers for use with Purchasing, and their store-specific identifier 
                 // counterparts for use with and outside of Unity Purchasing. Define store-specific identifiers 
                 // also on each platform's publisher dashboard (iTunes Connect, Google Play Developer Console, etc.)
 
                 // General product identifiers for the consumable, non-consumable, and subscription products.
                 // Use these handles in the code to reference which product to purchase. Also use these values 
                 // when defining the Product Identifiers on the store. Except, for illustration purposes, the 
                 // kProductIDSubscription - it has custom Apple and Google identifiers. We declare their store-
                 // specific mapping to Unity Purchasing's AddProduct, below.
                 public static string kProductIDConsumable =    "consumable";   
                 public static string kProductIDNonConsumable = "purchasethenextlevels";
                 public static string kProductIDSubscription =  "subscription"; 
                 public GameObject Trees;
 
                 // Apple App Store-specific product identifier for the subscription product.
                 private static string kProductNameAppleSubscription =  "com.unity3d.subscription.new";
 
                 // Google Play Store-specific product identifier subscription product.
                 private static string kProductNameGooglePlaySubscription =  "com.unity3d.subscription.original"; 
 
                 void Start()
                 {
                         // If we haven't set up the Unity Purchasing reference
                         if (m_StoreController == null)
                         {
                                 // Begin to configure our connection to Purchasing
                                 InitializePurchasing();
                         }
                 }
 
                 public void InitializePurchasing() 
                 {
                         // If we have already connected to Purchasing ...
                         if (IsInitialized())
                         {
                                 // ... we are done here.
                                 return;
                         }
 
                         // Create a builder, first passing in a suite of Unity provided stores.
                         var builder = ConfigurationBuilder.Instance(StandardPurchasingModule.Instance());
 
                         // Add a product to sell / restore by way of its identifier, associating the general identifier
                         // with its store-specific identifiers.
                         builder.AddProduct(kProductIDConsumable, ProductType.Consumable);
                         // Continue adding the non-consumable product.
                         builder.AddProduct(kProductIDNonConsumable, ProductType.NonConsumable);
                         // And finish adding the subscription product. Notice this uses store-specific IDs, illustrating
                         // if the Product ID was configured differently between Apple and Google stores. Also note that
                         // one uses the general kProductIDSubscription handle inside the game - the store-specific IDs 
                         // must only be referenced here. 
                         builder.AddProduct(kProductIDSubscription, ProductType.Subscription, new IDs(){
                                 { kProductNameAppleSubscription, AppleAppStore.Name },
                                 { kProductNameGooglePlaySubscription, GooglePlay.Name },
                         });
 
                         // Kick off the remainder of the set-up with an asynchrounous call, passing the configuration 
                         // and this class' instance. Expect a response either in OnInitialized or OnInitializeFailed.
                         UnityPurchasing.Initialize(this, builder);
                 }
 
 
                 private bool IsInitialized()
                 {
                         // Only say we are initialized if both the Purchasing references are set.
                         return m_StoreController != null && m_StoreExtensionProvider != null;
                 }
 
 
                 public void BuyConsumable()
                 {
                         // Buy the consumable product using its general identifier. Expect a response either 
                         // through ProcessPurchase or OnPurchaseFailed asynchronously.
                         BuyProductID(kProductIDConsumable);
                 }
 
 
                 public void BuyNonConsumable()
                 {
                         // Buy the non-consumable product using its general identifier. Expect a response either 
                         // through ProcessPurchase or OnPurchaseFailed asynchronously.
                         BuyProductID(kProductIDNonConsumable);
                 }
 
 
                 public void BuySubscription()
                 {
                         // Buy the subscription product using its the general identifier. Expect a response either 
                         // through ProcessPurchase or OnPurchaseFailed asynchronously.
                         // Notice how we use the general product identifier in spite of this ID being mapped to
                         // custom store-specific identifiers above.
                         BuyProductID(kProductIDSubscription);
                 }
 
 
                 void BuyProductID(string productId)
                 {
                         // If Purchasing has been initialized ...
                         if (IsInitialized())
                         {
                                 // ... look up the Product reference with the general product identifier and the Purchasing 
                                 // system's products collection.
                                 Product product = m_StoreController.products.WithID(productId);
 
                                 // If the look up found a product for this device's store and that product is ready to be sold ... 
                                 if (product != null && product.availableToPurchase)
                                 {
                                         Debug.Log(string.Format("Purchasing product asychronously: '{0}'", product.definition.id));
                                         // ... buy the product. Expect a response either through ProcessPurchase or OnPurchaseFailed 
                                         // asynchronously.
                                         m_StoreController.InitiatePurchase(product);
                                 }
                                 // Otherwise ...
                                 else
                                 {
                                         // ... report the product look-up failure situation  
                                         Debug.Log("BuyProductID: FAIL. Not purchasing product, either is not found or is not available for purchase");
                                 }
                         }
                         // Otherwise ...
                         else
                         {
                                 // ... report the fact Purchasing has not succeeded initializing yet. Consider waiting longer or 
                                 // retrying initiailization.
                                 Debug.Log("BuyProductID FAIL. Not initialized.");
                         }
                 }
 
 
                 // Restore purchases previously made by this customer. Some platforms automatically restore purchases, like Google. 
                 // Apple currently requires explicit purchase restoration for IAP, conditionally displaying a password prompt.
                 public void RestorePurchases()
                 {
                         // If Purchasing has not yet been set up ...
                         if (!IsInitialized())
                         {
                                 // ... report the situation and stop restoring. Consider either waiting longer, or retrying initialization.
                                 Debug.Log("RestorePurchases FAIL. Not initialized.");
                                 return;
                         }
 
                         // If we are running on an Apple device ... 
                         if (Application.platform == RuntimePlatform.IPhonePlayer || 
                                 Application.platform == RuntimePlatform.OSXPlayer)
                         {
                                 // ... begin restoring purchases
                                 Debug.Log("RestorePurchases started ...");
 
                                 // Fetch the Apple store-specific subsystem.
                                 var apple = m_StoreExtensionProvider.GetExtension<IAppleExtensions>();
                                 // Begin the asynchronous process of restoring purchases. Expect a confirmation response in 
                                 // the Action<bool> below, and ProcessPurchase if there are previously purchased products to restore.
                                 apple.RestoreTransactions((result) => {
                                         // The first phase of restoration. If no more responses are received on ProcessPurchase then 
                                         // no purchases are available to be restored.
                                         Debug.Log("RestorePurchases continuing: " + result + ". If no further messages, no purchases available to restore.");
                                 });
                         }
                         // Otherwise ...
                         else
                         {
                                 // We are not running on an Apple device. No work is necessary to restore purchases.
                                 Debug.Log("RestorePurchases FAIL. Not supported on this platform. Current = " + Application.platform);
                         }
                 }
 
 
                 //  
                 // --- IStoreListener
                 //
 
                 public void OnInitialized(IStoreController controller, IExtensionProvider extensions)
                 {
                         // Purchasing has succeeded initializing. Collect our Purchasing references.
                         Debug.Log("OnInitialized: PASS");
 
                         // Overall Purchasing system, configured with products for this application.
                         m_StoreController = controller;
                         // Store specific subsystem, for accessing device-specific store features.
                         m_StoreExtensionProvider = extensions;
                 }
 
 
                 public void OnInitializeFailed(InitializationFailureReason error)
                 {
                         // Purchasing set-up has not succeeded. Check error for reason. Consider sharing this reason with the user.
                         Debug.Log("OnInitializeFailed InitializationFailureReason:" + error);
                 }
 
 
                 public PurchaseProcessingResult ProcessPurchase(PurchaseEventArgs args) 
                 {
                         // A consumable product has been purchased by this user.
                         if (String.Equals(args.purchasedProduct.definition.id, kProductIDConsumable, StringComparison.Ordinal))
                         {
                                 Debug.Log(string.Format("ProcessPurchase: PASS. Product: '{0}'", args.purchasedProduct.definition.id));
                                 // The consumable item has been successfully purchased, add 100 coins to the player's in-game score.
                                 //ScoreManager.score += 100;
                         }
                         // Or ... a non-consumable product has been purchased by this user.
                         else if (String.Equals(args.purchasedProduct.definition.id, kProductIDNonConsumable, StringComparison.Ordinal))
                         {
                                 Debug.Log(string.Format("ProcessPurchase: PASS. Product: '{0}'", args.purchasedProduct.definition.id));
                                 Trees.SetActive(true);
                                 // TODO: The non-consumable item has been successfully purchased, grant this item to the player.
 
 
                         }
                     
                         // Or ... a subscription product has been purchased by this user.
                         else if (String.Equals(args.purchasedProduct.definition.id, kProductIDSubscription, StringComparison.Ordinal))
                         {
                                 Debug.Log(string.Format("ProcessPurchase: PASS. Product: '{0}'", args.purchasedProduct.definition.id));
                                 // TODO: The subscription item has been successfully purchased, grant this to the player.
                         }
                         // Or ... an unknown product has been purchased by this user. Fill in additional products here....
                         else 
                         {
                                 Debug.Log(string.Format("ProcessPurchase: FAIL. Unrecognized product: '{0}'", args.purchasedProduct.definition.id));
                         }
 
                         // Return a flag indicating whether this product has completely been received, or if the application needs 
                         // to be reminded of this purchase at next app launch. Use PurchaseProcessingResult.Pending when still 
                         // saving purchased products to the cloud, and when that save is delayed. 
                         return PurchaseProcessingResult.Complete;
                 }
 
 
                 public void OnPurchaseFailed(Product product, PurchaseFailureReason failureReason)
                 {
                         // A product purchase attempt did not succeed. Check failureReason for more detail. Consider sharing 
                         // this reason with the user to guide their troubleshooting actions.
                         Debug.Log(string.Format("OnPurchaseFailed: FAIL. Product: '{0}', PurchaseFailureReason: {1}", product.definition.storeSpecificId, failureReason));
                 }
         }
 }

Comment
Add comment · Show 1
10 |3000 characters needed characters left characters exceeded
â–¼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users
avatar image loriarty · Jul 19, 2017 at 11:15 AM 0
Share

i think the problem in the line number 220 do you have any solution for this

0 Replies

· Add your reply
  • Sort: 

Your answer

Hint: You can notify a user about this post by typing @username

Up to 2 attachments (including images) can be used with a maximum of 524.3 kB each and 1.0 MB total.

Follow this Question

Answers Answers and Comments

68 People are following this question.

avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image

Related Questions

Error: Null Reference Exception 1 Answer

#Need Fast Help# NullReferenceException: Object reference not set to an instance of an object 0 Answers

NullReferenceException when attempting to call a GameObject from within PointerEventData 1 Answer

getcomponent cant find every button script in every gameobject 1 Answer

How to destroy on exiting PlayMode/EditMode? 1 Answer


Enterprise
Social Q&A

Social
Subscribe on YouTube social-youtube Follow on LinkedIn social-linkedin Follow on Twitter social-twitter Follow on Facebook social-facebook Follow on Instagram social-instagram

Footer

  • Purchase
    • Products
    • Subscription
    • Asset Store
    • Unity Gear
    • Resellers
  • Education
    • Students
    • Educators
    • Certification
    • Learn
    • Center of Excellence
  • Download
    • Unity
    • Beta Program
  • Unity Labs
    • Labs
    • Publications
  • Resources
    • Learn platform
    • Community
    • Documentation
    • Unity QA
    • FAQ
    • Services Status
    • Connect
  • About Unity
    • About Us
    • Blog
    • Events
    • Careers
    • Contact
    • Press
    • Partners
    • Affiliates
    • Security
Copyright © 2020 Unity Technologies
  • Legal
  • Privacy Policy
  • Cookies
  • Do Not Sell My Personal Information
  • Cookies Settings
"Unity", Unity logos, and other Unity trademarks are trademarks or registered trademarks of Unity Technologies or its affiliates in the U.S. and elsewhere (more info here). Other names or brands are trademarks of their respective owners.
  • Anonymous
  • Sign in
  • Create
  • Ask a question
  • Spaces
  • Default
  • Help Room
  • META
  • Moderators
  • Explore
  • Topics
  • Questions
  • Users
  • Badges