0

私のアプリには、ボタンを押すとユーザーがアプリをアップグレードして広告を削除できるというコードがあり、MKStoreKitを呼び出し、ユーザーがアップグレードを購入すると、アプリが再起動されるまで広告はアプリに残ります。

これを修正したいので、広告はすぐに削除されますが、どうすればこれを実行できますか?

ここにいくつかのコードがあります。

-(IBAction)removeAds:(id)sender
{

    if (![MKStoreManager isFeaturePurchased:@"com.davidsapps.puzzler.removeads"]) { //

        UIAlertView *alert = [[UIAlertView alloc]initWithTitle:@"Upgrade App" message:@"To upgrade and remove all advertisements from this app Please click OK to purchase the upgrade!" delegate:self cancelButtonTitle:@"No Thanks" otherButtonTitles:@"Yes Please",nil];
        [alert show];
        [alert release];
    }

}

リンク先のアラート。

- (void)alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex
{
    if (buttonIndex == 0){
        //cancel button clicked. Do something here or nothing here
    }
    else{
        //other button indexes clicked
        [[MKStoreManager sharedManager] buyFeature:@- (void)alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex
{
    if (buttonIndex == 0){
        //cancel button clicked. Do something here or nothing here
    }
    else{
        //other button indexes clicked
        [[MKStoreManager sharedManager] buyFeature:@"com.idevver.mybatterypal.upgrade"];
    }
    }
}

MKStoreKitの使用

ユーザーがアプリを再起動せずに広告を削除するためにできることはありますか?

ありがとう、

クリス

編集-広告はAdmobメディエーションであり、ViewDidLoadでこのコードを使用します

- (void)viewDidLoad {


        bannerView_ = [[GADBannerView alloc] initWithAdSize:kGADAdSizeSmartBannerPortrait];
        bannerView_.adUnitID = MY_BANNER_UNIT_ID;
        CGRect screenRect = [[UIScreen mainScreen] bounds];
        CGFloat screenWidth = screenRect.size.width;
        CGFloat screenHeight = screenRect.size.height;
        CGFloat screenXPos = (screenWidth /2);
        CGFloat screenYPos = screenHeight - 90;
        [bannerView_ setCenter:CGPointMake(screenXPos, screenYPos)];
        bannerView_.rootViewController = self;
        bannerView_.adUnitID = MY_BANNER_UNIT_ID;
        bannerView_.rootViewController = self;
        [self.view addSubview:bannerView_];

これは実際に広告バナーを呼び出すコードであり、後のviewDidLoadのif/elseステートメントにあります。

if (![MKStoreManager isFeaturePurchased:@"com.davidsapps.puzzler.removeads"]) { //


        [bannerView_ loadRequest:[GADRequest request]];
    }

だから私はどういうわけか機能を購入したときに、MKStoreManager.mファイルに上記のbannerView_コードを却下するという何かを追加する必要があると思いますか?

それはうまくいくでしょうか?

編集2-アプリ内コードの完全な.mファイル(素晴らしいキットを提供してくれたMugunthKumarに感謝します)

//
//  MKStoreManager.m
//  MKStoreKit
//
//  Created by Mugunth Kumar on 17-Nov-2010.
//  Copyright 2010 Steinlogic. All rights reserved.
//  File created using Singleton XCode Template by Mugunth Kumar (http://mugunthkumar.com
//  Permission granted to do anything, commercial/non-commercial with this file apart from removing the line/URL above
//  Read my blog post at http://mk.sg/1m on how to use this code

//  As a side note on using this code, you might consider giving some credit to me by
//  1) linking my website from your app's website 
//  2) or crediting me inside the app's credits page 
//  3) or a tweet mentioning @mugunthkumar
//  4) A paypal donation to mugunth.kumar@gmail.com
//
//  A note on redistribution
//  While I'm ok with modifications to this source code, 
//  if you are re-publishing after editing, please retain the above copyright notices

#import "MKStoreManager.h"
#import "GADBannerView.h"
#import "AppDelegate.h"

@interface MKStoreManager (PrivateMethods)

- (void) requestProductData;
- (BOOL) canCurrentDeviceUseFeature: (NSString*) featureID;
- (BOOL) verifyReceipt:(NSData*) receiptData;
- (void) enableContentForThisSession: (NSString*) productIdentifier;

@end

@implementation MKStoreManager

@synthesize purchasableObjects = _purchasableObjects;
@synthesize storeObserver = _storeObserver;

static NSString *ownServer = nil;

static __weak id<MKStoreKitDelegate> _delegate;
static MKStoreManager* _sharedStoreManager;


- (void)dealloc {

    [_purchasableObjects release];
    [_storeObserver release];

    [_sharedStoreManager release];
    [super dealloc];
}

#pragma mark Delegates

+ (id)delegate {

    return _delegate;
}

+ (void)setDelegate:(id)newDelegate {

    _delegate = newDelegate;    
}

#pragma mark Singleton Methods

+ (MKStoreManager*)sharedManager
{
    @synchronized(self) {

        if (_sharedStoreManager == nil) {

#if TARGET_IPHONE_SIMULATOR
            NSLog(@"You are running in Simulator MKStoreKit runs only on devices");
#else
            _sharedStoreManager = [[self alloc] init];                  
            _sharedStoreManager.purchasableObjects = [[NSMutableArray alloc] init];
            [_sharedStoreManager requestProductData];                       
            _sharedStoreManager.storeObserver = [[MKStoreObserver alloc] init];
            [[SKPaymentQueue defaultQueue] addTransactionObserver:_sharedStoreManager.storeObserver];           
#endif
        }
    }
    return _sharedStoreManager;
}


+ (id)allocWithZone:(NSZone *)zone

{   
    @synchronized(self) {

        if (_sharedStoreManager == nil) {

            _sharedStoreManager = [super allocWithZone:zone];           
            return _sharedStoreManager;  // assignment and return on first allocation
        }
    }

    return nil; //on subsequent allocation attempts return nil  
}


- (id)copyWithZone:(NSZone *)zone
{
    return self;    
}

- (id)retain
{   
    return self;    
}

- (unsigned)retainCount
{
    return UINT_MAX;  //denotes an object that cannot be released
}

- (void)release
{
    //do nothing
}

- (id)autorelease
{
    return self;    
}

#pragma mark Internal MKStoreKit functions

- (void) restorePreviousTransactions
{
    [[SKPaymentQueue defaultQueue] restoreCompletedTransactions];
}

-(void) requestProductData
{
    SKProductsRequest *request= [[SKProductsRequest alloc] initWithProductIdentifiers:[NSSet setWithObjects: 
                                  kFeatureAId,
                                  kConsumableFeatureBId,
                                  kConsumableBaseFeatureId,
                                  nil]];
    request.delegate = self;
    [request start];
}

- (void)productsRequest:(SKProductsRequest *)request didReceiveResponse:(SKProductsResponse *)response
{
    [self.purchasableObjects addObjectsFromArray:response.products];

#ifndef NDEBUG  
    for(int i=0;i<[self.purchasableObjects count];i++)
    {       
        SKProduct *product = [self.purchasableObjects objectAtIndex:i];
        NSLog(@"Feature: %@, Cost: %f, ID: %@",[product localizedTitle],
              [[product price] doubleValue], [product productIdentifier]);
    }

    for(NSString *invalidProduct in response.invalidProductIdentifiers)
        NSLog(@"Problem in iTunes connect configuration for product: %@", invalidProduct);
#endif

    [request autorelease];

    isProductsAvailable = YES;

    if([_delegate respondsToSelector:@selector(productFetchComplete)])
        [_delegate productFetchComplete];   
}


// call this function to check if the user has already purchased your feature
+ (BOOL) isFeaturePurchased:(NSString*) featureId
{


    return [[NSUserDefaults standardUserDefaults] boolForKey:featureId];

}

// Call this function to populate your UI
// this function automatically formats the currency based on the user's locale

- (NSMutableArray*) purchasableObjectsDescription
{
    NSMutableArray *productDescriptions = [[NSMutableArray alloc] initWithCapacity:[self.purchasableObjects count]];
    for(int i=0;i<[self.purchasableObjects count];i++)
    {
        SKProduct *product = [self.purchasableObjects objectAtIndex:i];

        NSNumberFormatter *numberFormatter = [[NSNumberFormatter alloc] init];
        [numberFormatter setFormatterBehavior:NSNumberFormatterBehavior10_4];
        [numberFormatter setNumberStyle:NSNumberFormatterCurrencyStyle];
        [numberFormatter setLocale:product.priceLocale];
        NSString *formattedString = [numberFormatter stringFromNumber:product.price];
        [numberFormatter release];

        // you might probably need to change this line to suit your UI needs
        NSString *description = [NSString stringWithFormat:@"%@ (%@)",[product localizedTitle], formattedString];

#ifndef NDEBUG
        NSLog(@"Product %d - %@", i, description);
#endif
        [productDescriptions addObject: description];
    }

    [productDescriptions autorelease];
    return productDescriptions;
}


- (void) buyFeature:(NSString*) featureId
{


    if([self canCurrentDeviceUseFeature: featureId])
    {
        UIAlertView *alert = [[UIAlertView alloc] initWithTitle:NSLocalizedString(@"Review request approved", @"")
                                                        message:NSLocalizedString(@"You can use this feature for reviewing the app.", @"")
                                                       delegate:self 
                                              cancelButtonTitle:NSLocalizedString(@"Dismiss", @"")
                                              otherButtonTitles:nil];
        [alert show];
        [alert release];

        [self enableContentForThisSession:featureId];
        return;
    }

    if ([SKPaymentQueue canMakePayments])
    {
        SKPayment *payment = [SKPayment paymentWithProductIdentifier:featureId];
        [[SKPaymentQueue defaultQueue] addPayment:payment];
    }
    else
    {
        UIAlertView *alert = [[UIAlertView alloc] initWithTitle:NSLocalizedString(@"In-App Purchasing disabled", @"")
                                                        message:NSLocalizedString(@"Check your parental control settings and try again later", @"")
                                                       delegate:self 
                                              cancelButtonTitle:NSLocalizedString(@"Dismiss", @"")
                                              otherButtonTitles: nil];
        [alert show];
        [alert release];

    }
}

- (BOOL) canConsumeProduct:(NSString*) productIdentifier
{
    int count = [[NSUserDefaults standardUserDefaults] integerForKey:productIdentifier];

    return (count > 0);

}

- (BOOL) canConsumeProduct:(NSString*) productIdentifier quantity:(int) quantity
{
    int count = [[NSUserDefaults standardUserDefaults] integerForKey:productIdentifier];
    return (count >= quantity);
}

- (BOOL) consumeProduct:(NSString*) productIdentifier quantity:(int) quantity
{
    int count = [[NSUserDefaults standardUserDefaults] integerForKey:productIdentifier];
    if(count < quantity)
    {
        return NO;
    }
    else 
    {
        count -= quantity;
        [[NSUserDefaults standardUserDefaults] setInteger:count forKey:productIdentifier];
        return YES;
    }

}

-(void) enableContentForThisSession: (NSString*) productIdentifier
{
    if([_delegate respondsToSelector:@selector(productPurchased:)])
        [_delegate productPurchased:productIdentifier];

}


#pragma mark In-App purchases callbacks
// In most cases you don't have to touch these methods
-(void) provideContent: (NSString*) productIdentifier 
           forReceipt:(NSData*) receiptData
{
    if(ownServer != nil && SERVER_PRODUCT_MODEL)
    {
        // ping server and get response before serializing the product
        // this is a blocking call to post receipt data to your server
        // it should normally take a couple of seconds on a good 3G connection
        if(![self verifyReceipt:receiptData]) return;
    }

    NSRange range = [productIdentifier rangeOfString:kConsumableBaseFeatureId];     
    NSString *countText = [productIdentifier substringFromIndex:range.location+[kConsumableBaseFeatureId length]];

    int quantityPurchased = [countText intValue];
    if(quantityPurchased != 0)
    {

        int oldCount = [[NSUserDefaults standardUserDefaults] integerForKey:productIdentifier];
        oldCount += quantityPurchased;  

        [[NSUserDefaults standardUserDefaults] setInteger:oldCount forKey:productIdentifier];       
    }
    else 
    {
        [[NSUserDefaults standardUserDefaults] setBool:YES forKey:productIdentifier];       
    }

    [[NSUserDefaults standardUserDefaults] synchronize];

    if([_delegate respondsToSelector:@selector(productPurchased:)])
        [_delegate productPurchased:productIdentifier];

UIAlertView* alert = [[UIAlertView alloc] initWithTitle:@"In-App Upgrade" message:@"Successfull removal of advertisements upgrade - thankyou" delegate:self cancelButtonTitle:@"ok" otherButtonTitles:nil, nil];

[alert show];
[alert release];

}

- (void) transactionCanceled: (SKPaymentTransaction *)transaction
{

#ifndef NDEBUG
    NSLog(@"User cancelled transaction: %@", [transaction description]);
#endif

    if([_delegate respondsToSelector:@selector(transactionCanceled)])
        [_delegate transactionCanceled];
}

- (void) failedTransaction: (SKPaymentTransaction *)transaction
{
    UIAlertView *alert = [[UIAlertView alloc] initWithTitle:[transaction.error localizedFailureReason] 
                                                    message:[transaction.error localizedRecoverySuggestion]
                                                   delegate:self 
                                          cancelButtonTitle:NSLocalizedString(@"Dismiss", @"")
                                          otherButtonTitles: nil];
    [alert show];
    [alert release];
}



#pragma mark In-App purchases promo codes support
// This function is only used if you want to enable in-app purchases for free for reviewers
// Read my blog post http://mk.sg/31
- (BOOL) canCurrentDeviceUseFeature: (NSString*) featureID
{
    NSString *uniqueID = [[UIDevice currentDevice] uniqueIdentifier];
    // check udid and featureid with developer's server

    if(ownServer == nil) return NO; // sanity check

    NSURL *url = [NSURL URLWithString:[NSString stringWithFormat:@"%@/%@", ownServer, @"featureCheck.php"]];

    NSMutableURLRequest *theRequest = [NSMutableURLRequest requestWithURL:url 
                                                              cachePolicy:NSURLRequestReloadIgnoringCacheData 
                                                          timeoutInterval:60];

    [theRequest setHTTPMethod:@"POST"];     
    [theRequest setValue:@"application/x-www-form-urlencoded" forHTTPHeaderField:@"Content-Type"];

    NSString *postData = [NSString stringWithFormat:@"productid=%@&udid=%@", featureID, uniqueID];

    NSString *length = [NSString stringWithFormat:@"%d", [postData length]];    
    [theRequest setValue:length forHTTPHeaderField:@"Content-Length"];  

    [theRequest setHTTPBody:[postData dataUsingEncoding:NSASCIIStringEncoding]];

    NSHTTPURLResponse* urlResponse = nil;
    NSError *error = [[[NSError alloc] init] autorelease];  

    NSData *responseData = [NSURLConnection sendSynchronousRequest:theRequest
                                                 returningResponse:&urlResponse 
                                                             error:&error];  

    NSString *responseString = [[NSString alloc] initWithData:responseData encoding:NSASCIIStringEncoding];

    BOOL retVal = NO;
    if([responseString isEqualToString:@"YES"])     
    {
        retVal = YES;
    }

    [responseString release];
    return retVal;
}

// This function is only used if you want to enable in-app purchases for free for reviewers
// Read my blog post http://mk.sg/

-(BOOL) verifyReceipt:(NSData*) receiptData
{
    if(ownServer == nil) return NO; // sanity check

    NSURL *url = [NSURL URLWithString:[NSString stringWithFormat:@"%@/%@", ownServer, @"verifyProduct.php"]];

    NSMutableURLRequest *theRequest = [NSMutableURLRequest requestWithURL:url 
                                                              cachePolicy:NSURLRequestReloadIgnoringCacheData 
                                                          timeoutInterval:60];

    [theRequest setHTTPMethod:@"POST"];     
    [theRequest setValue:@"application/x-www-form-urlencoded" forHTTPHeaderField:@"Content-Type"];

    NSString *receiptDataString = [[NSString alloc] initWithData:receiptData encoding:NSASCIIStringEncoding];
    NSString *postData = [NSString stringWithFormat:@"receiptdata=%@", receiptDataString];
    [receiptDataString release];

    NSString *length = [NSString stringWithFormat:@"%d", [postData length]];    
    [theRequest setValue:length forHTTPHeaderField:@"Content-Length"];  

    [theRequest setHTTPBody:[postData dataUsingEncoding:NSASCIIStringEncoding]];

    NSHTTPURLResponse* urlResponse = nil;
    NSError *error = [[[NSError alloc] init] autorelease];  

    NSData *responseData = [NSURLConnection sendSynchronousRequest:theRequest
                                                 returningResponse:&urlResponse 
                                                             error:&error];  

    NSString *responseString = [[NSString alloc] initWithData:responseData encoding:NSASCIIStringEncoding];

    BOOL retVal = NO;
    if([responseString isEqualToString:@"YES"])     
    {
        retVal = YES;
    }

    [responseString release];
    return retVal;
}
@end
4

1 に答える 1

0

購入が完了したら、広告を削除するのはあなた次第です。これと同じようなことをしてください。

[bannerView removeFromSuperview];

あなたがしなければならないのは、購入が完了したときに広告を非表示にすることです。

于 2012-12-20T00:48:40.523 に答える