Table of Contents
- 1 Frequently Asked Questions
- 1.1 General Questions:
- 1.1.1 Where can I download the SDK?
- 1.1.2 How much size will the Tapjoy SDK add to my application?
- 1.1.3 What device operating systems are supported?
- 1.1.4 What development environments does Tapjoy 11 support?
- 1.1.5 What open source software is included in the Tapjoy SDK?
- 1.1.6 What information does the Tapjoy SDK send to Tapjoy?
- 1.1.7 I’ve integrated Tapjoy but I don’t see any ads. What is wrong?
- 1.1.8 How long will it take for these custom cohorts to appear in my dashboard once they are integrated and my app starts sending them?
- 1.1.9 Can I create a custom user segment by uploading a list of Advertiser IDs?
- 1.1.10 Where are Tapjoy’s servers physically located?
- 1.1.11 I installed an app from the offerwall, but I did not get a reward. What is happening?
- 1.1.12 How do I enable Tapjoy debug mode?
- 1.1.13 Do I have to wait for my content to finish preloading before I can show an ad?
- 1.1.14 How much memory is used during video playback?
- 1.1.15 Do you support Android permissions ACCESS_FINE_LOCATION or ACCESS_COARSE_LOCATION?
- 1.1.16 Why in-app purchase data is not matching App store numbers?
- 1.1.17 Where do I go if I need help or assistance?
- 1.2 Unity
- 1.3 Air
- 1.1 General Questions:
- 2 Glossary
- 3 Articles
- 3.1 Customer Service Tool
- 3.2 Custom Exchange Rates
- 3.3 iOS 11 and Tapjoy
- 3.4 Ad Retention Report
- 3.5 Publisher Reporting API with Country/Geo Breakdown
- 3.7 iOS Data Authorization info.plist changes
- 3.8 NSCalendarsUsageDescription iOS app store rejection solution
- 3.9 Tapjoy SDK and Apple’s iOS IPv6 requirements
- 3.10 User Tags
- 3.11 Native to Earn
- 3.12 Preparing for iOS 9
- 3.13 Unexpected CFBundleExecutable Key iOS submission error
- 3.14 Publisher Integration Checklist
- 3.15 Ad Reporting API
- 3.16 Analytics Data Export API
- 3.17 How to send an automated push
- 3.18 How to configure your push certificate
- 3.19 How to find sender ID and api key for FCM
- 3.20 Using Multiple Push Providers
- 3.21 Device Identifiers
- 3.22 How to use custom payload in push notification
- 3.23 How to Integrate Pay Per Engagement (PPE, also PPA or CPE) Campaigns
- 3.24 Dashboard User Roles and Permissions
- 3.25 Testflight, IDFA, and testing Tapjoy
- 3.26 Setting up test devices on Tapjoy dashboard
- 3.27 Tapjoy Device Content Cache
- 3.28 Switching from showOffers to Placement and Content
- 3.29 Integrating Tapjoy SDK with Swift Apps
- 3.30 Using Custom Events In Tapjoy
- 3.31 User Cohorts Guide
- 3.32 Options on reducing total method count in Tapjoy Android Apps
- 3.33 Push Troubleshooting Guide
- 3.34 Ad Behavioral Targeting
- 3.35 A/B Testing
- 3.36 How to find the Tapjoy SDK Key
- 3.37 How to Read the Developer Console
Frequently Asked Questions
Where can I download the SDK?
Here is our SDK Download Page.
How much size will the Tapjoy SDK add to my application?
For Android, the 12.2.0 SDK adds 664KB (the size of the library jar) to your app and has a method count of approximately 5352.
For iOS, SDK 11.11, has adds 1.89MB across all architectures. (The arm64 slice, which recent iOS devices will use, is about 1MB.) This is the difference between the size of a compiled empty app vs. that app compiled with Tapjoy and all required frameworks added. For SDK 12.0.0, the arm64 slice adds 1.12 MB to the size of the application.
What device operating systems are supported?
Tapjoy 12 supports iOS 8 and higher and Android 4.0 (API Level 14/Ice Cream Sandwich) and higher.
What development environments does Tapjoy 11 support?
What open source software is included in the Tapjoy SDK?
Here is the open source list for Tapjoy SDK 11.
What information does the Tapjoy SDK send to Tapjoy?
This comprehensive parameter list explains everything the Tapjoy SDK sends to Tapjoy servers.
I’ve integrated Tapjoy but I don’t see any ads. What is wrong?
- There are a number of reasons why you might not be seeing advertisements. Please check the following list of causes:The most common reason for not seeing ads is that there is no advertising content associated with the placement. Once you set up the placement on the dashboard and integrate it into your code, it will not actually show anything until you link content to it.
- The placement is integrated in code, but not set up on the dashboard.
- The placement name in your app’s code does not exactly match the placement in the dashboard. For example, if you have "app open" in your code, but "app launch" set up on the dashboard, calling the "app open" placement will return no content, and you will not see any ads. Check the names of the placements in code and in the dashboard, paying particular attention to spaces (" "), underscores "_", spelling, and common synonyms (e.g. "exit_store" vs. "quit_store").
- The app does not yet have an approved currency. In order to use Tapjoy to show advertisements, you must set up at least 1 currency in the dashboard. To see your virtual currency status, go to Settings -> App Settings -> Content -> Virtual Currency. Note that if your application runs on both iOS and Android, you must have an approved currency on each platform to see ads on that platform.
- You are calling the placement before Tapjoy has successfully connected. You must wait until the Tapjoy Connect call has successfully completed before calling your placement, otherwise the placement call will fail and you will see no content. (In fact, almost all Tapjoy calls will fail if executed before Tapjoy has successfully connected.) Note that just putting the placement call in your code after the connect call in your code does not guarantee that the placement will be called after the connect call succeeds. The connect call is asynchronous. You should wait until the appropriate Tapjoy connection success delegate/listener (iOS, Android, Unity, Air) is called before calling placements.
- You are using the wrong SDK Key in your app. Check that the SDK Key in your apps code matches the SDK key in the correct app in your dashboard. Often when copying & pasting Tapjoy code from one project to another, an SDK key from another app or from the wrong platform can get into your code.
- There is not any "fill" for your region for that kind of ad. At times, Tapjoy does not have any ads to show for a particular format in a particular region. This is more likely to happen in smaller markets. To determine whether a lack of content is due to fill or due to an implementation issue, it is often useful to designate a device as a test device. A test device will see a test advertisement from Tapjoy even if there is no actual ad inventory for that region. (Note that sometimes this test advertisement will only actually reward the user once every 5 minutes, depending on the ad format. This is to curb fraud.) To designate a device as a test device, go to App Settings->Test Devices->Create Test Device.
- You are on a VPN. If your are on a VPN, our system might think your device is pretending to be in a different region, and not provide any ads as an anti-fraud precaution. This is particularly likely to happen if your VPN makes your device have an IP address that does not match other characteristics of the device, such as its country code.
- Your Ad content is set to Test Devices Only and you are checking for ads with a non-test device. Either set the content to be viewable by all devices (Content->Scroll down to content list->Find content unit->Click Edit icon->Uncheck the "Test Only" box), or use a properly configured test device (Dashboard->App Settings->Test Devices) to view the content.
- You are trying to see a test ad for an ad content unit that has its currency set to "non-rewarded". If an ad unit (Video) is set to "non-rewarded", you will not see any test advertisements for it, even if your device is set up as a test device.
- If your exchange rate (App Settings->Content->Virtual Currency->Exchange Rate) is too low, there may not be any ads available that pay at least one unit of your currency. For example, if you set your "gems" currency to 1 gem = 1 U.S. Dollar, only ads that pay at least 1 USD would be shown. Since few ads pay that much, it is likely you would not see any ads at all. While our system does do some shifting to help make offers appear in these types of situations, we recommend your currency exchange rate be set to at least 100 = $1 USD. That will ensure you are not losing out on ad inventory due to your currency being too expensive.
- If you see content the first time it is shown, but not on subsequent shows, you might not be loading content again once you have shown it. Once you display the placement to the user, you must make the placement call again to "reload" the placement. If you do not do this, subsequent attempts to show that placement will fail.
- You’re not connected to the internet. Obviously, Tapjoy requires connectivity to its servers in order to show advertising content to the user. If the device or simulator you are using does not have connectivity, no ads will appear.
- You are running in the Unity3d editor. If you are using Tapjoy with Unity3d, you must actually build to a device to check your Tapjoy integration. Tapjoy does not function properly when your app is being run within the Unity3d editor.
- The clock on your device does not match present time. This will cause the SSL handshake to fail, which will prevent Tapjoy’s connect call from succeeding, which in turn will prevent you from seeing Tapjoy content.
- You are using the same Publisher User ID across many devices. Sometimes, when testing, an engineer or tester will run the game on many devices. If our system detects the same publisher user ID being used across a large number of devices, we assume it is a user attempting to set up a fraudulent "click farm" to complete ad offers, and we stop showing content to the user ID. For security purposes, we do not release the exact thresholds that trigger this. As a workaround, one can use different user IDs on different test devices.
- Your content has an eCPM floor or goal for the current region and Tapjoy does not have any content that can meet that floor or goal. This can happen if those floors are too high, or if Tapjoy’s algorithm has come to think of a user as less likely to install (this often happens with test accounts and devices) and is therefore bidding lower for that user.
How long will it take for these custom cohorts to appear in my dashboard once they are integrated and my app starts sending them?
The custom cohorts on the dashboard are created daily, so it might take up to 24 hours for them to appear.
Can I create a custom user segment by uploading a list of Advertiser IDs?
Yes. Follow the instructions for uploading Advertiser IDs.
Where are Tapjoy’s servers physically located?
Tapjoy has a global customer base. To serve this customer base, Tapjoy has servers hosted in the Asia-Pacific region, Western Europe, Western United States, and Eastern United States. This ensures both redundancy and high performance for multiple geographic regions.
I installed an app from the offerwall, but I did not get a reward. What is happening?
Before the install can be tracked you must first open and run the advertised application. Once you run the application that will make it track the install, and once Tapjoy gets the install tracking data you will be rewarded. In most cases the installs are tracked within a few minutes. However in the worst cases it can take over an hour before the install tracking service reports the install to our servers.
How do I enable Tapjoy debug mode?
Do I have to wait for my content to finish preloading before I can show an ad?
Once you get the isContentAvailable response you do not necessarily need to wait for the content to finish pre-loading. If you call showContent before the content has finished loading, the SDK will attempt to stream the remaining ad. We recommend waiting for the SDK callback for content ready so that you know all of the content has finished downloading. Otherwise the user might see the ad buffering while it downloads.
How much memory is used during video playback?
On average, for iOS a video will use approximately 7mb of memory. For Android, its closer to 10mb of memory on video playback.
Do you support Android permissions ACCESS_FINE_LOCATION or ACCESS_COARSE_LOCATION?
Our Android-SDKs do have support for the location permissions. With Android 6, Google has marked these permissions as "dangerous" so users are prompted to accept these permissions at runtime. Therefore we do not recommend using these permissions unless your app already has a strong use-case for requiring Location permissions. The permissions are entirely optional and safe to exclude from your app.
Why in-app purchase data is not matching App store numbers?
The discrepancy could be caused by,
1. When receipt validation is not used.
2. Our IAP tracking does not include refund events so if a user requests a refund, we aren’t able to track this and adjust the revenue numbers.
3. Geo detection if there is a discrepancy on country-specific data: We detect user’s country with IP or SIM country but stores know user’s account is bound with the country and they use such info. In case of 1, if the discrepancy is in Android, a setting should be setup for IAP receipt validation.
It can be found in Tapjoy LTV dasboard -> app settings.
Where do I go if I need help or assistance?
Can I run and test Tapjoy in the Unity3d Editor?
No. You must build to an actual device to test Tapjoy. If you try to run Tapjoy in the Unity editor, you will get a message like the following:
E/TapjoyConnect(20815): ERROR -- call requestTapjoyConnect and make sure to receive the Tapjoy connectSuccess response from the TapjoyConnectNotifier before calling any other Tapjoy methods
Can I control when the SDK first connects?
In SDK 11.2.1 and below this is not possible. In SDK 11.2.2 and above it is possible to programmatically control the connection step. You can find the documentation here.
Encountering the following error: [iOS] [Win] Installation Error: ApplicationVerificationFailed message appears on installing IPA using adt command if there is any info plist inside the assets or ANE?
AIR 22 official version will fix this issue. Until then please use the osx environment.