در صورت وجود مشکل یا ابهام به لیست خطاهای فنی رایج مراجعه کنید یا صفحهی Github Issues را بررسی نمایید.
اضافه کردن Unity Package تپسل پلاس
۱. ابتدا فایل unitypackage resolver را دانلود کنید. سپس مطابق توضیحات لینک زیر آن را به پروژهی خود اضافه نمایید:
۲. از طریق منوهای زیر، تیک مربوط به Jetifier
و Auto Resolution
را بزنید. (تیک مربوط به Auto Resolution
اجباری نیست اما برای آن که هر بار مجبور نباشید کتابخانهها را به شکل دستی Resolve کنید بهتر است آن را فعال کنید)
Assets > External Dependency Manager > Android Resolver > Settings > Use Jetifier
Assets > External Dependency Manager > Android Resolver > Settings > Enable Auto-Resolution
۳. ابتدا unitypackage
تپسل پلاس را از این لینک دریافت نمایید.
۴. از طریق منوی زیر unitypackage
تپسل پلاس را به پروژهی خود اضافه نمایید. (اگر فولدر TapsellPlusSDK
از قبل در پروژهی شما وجود دارد لطفا آن را پاک کنید)
Assets > Import Package > Custom Package...
۵. برای اطمینان از اضافه شدن پلاگین تپسل پلاس از طریق منوی زیر اقدام به Resolve کردن کتابخانهها کنید:
Assets > External Dependency Manager > Android Resolver > Force Resolve
در صورت مواجه با خطای resolution failed و عدم دانلود پکیج های aar در مسیر Plugins/Android ، اطمینان حاصل کنید که از ابزارهای تحریم شکن مانند shecan یا 403.online در زمان resolve استفاده میکنید. همچنین میتوانید تمامی پکیج های aar مربوطه را از این لینک نیز دانلود نمایید.
۶. از طریق منوهای زیر، تیکهای مربوط به ایجاد فایلهای Custom Gradle را بزنید:
Edit > Project Setting... > Player > Publishing Settings > Custom Launcher Gradle Template
Edit > Project Setting... > Player > Publishing Settings > Custom Base Gradle Template
Edit > Project Setting... > Player > Publishing Settings > Custom Gradle Properties Template
Edit > Project Setting... > Player > Publishing Settings > Custom Main Manifest
۷. در صورتیکه از یونیتی ۲۰۲۱ یا پایین تر استفاده میکنید، برای فعال سازی AndroidX در پروژه، به آدرس Assets\Plugins\Android\gradleTemplate.properties
بروید و قطعه کد زیر را اضافه کنید:
android.useAndroidX=true
android.enableJetifier=true
در نسخه های جدیدتر یونیتی، AndroidX به صورت پیش فرض فعال است و نیازی به اضافه کردن این کد نیست.
۸. در صورتیکه از یونیتی ۲۰۲۱ یا پایین تر استفاده میکنید، به آدرس Assets\Plugins\Android\launcherTemplate.gradle
بروید و اطمینان حاصل کنید که همانند کد زیر، از نسخه جاوا ۸ یا بالاتر استفاده شده است:
android {
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8 // or JavaVersion.VERSION_11 and above
targetCompatibility JavaVersion.VERSION_1_8 // or JavaVersion.VERSION_11 and above
}
}
۹. در صورتیکه از یونیتی ۲۰۲۱ یا پایین تر استفاده میکنید، به آدرس Assets\Plugins\Android\baseProjectTemplate.gradle
بروید و مخزن mavenCentral()
را به هر دو بخش repositories
اضافه نمایید. در نسخه های جدیدتر یونیتی این مخزن به صورت پیش فرض در فایل Assets\Plugins\Android\settingsTemplate.gradle
وجود دارد.
۱۰. در صورتیکه بازی شما، دستگاه های اندروید ۵ یا پایینتر را پوشش میدهد، بعد از اضافه کردن تپسل پلاس و شبکههای تبلیغاتی دیگر احتمالا به دلیل بالا رفتن حجم کد و جلوگیری از وقوع خطای زیر میبایستی MultiDex را فعال نمایید. در صورتیکه از minSdkVersion
نسخهی ۲۱ یا بالاتر استفاده میکنید، MultiDex به صورت پیش فرض فعال است. در غیر اینصورت لازم است آن را به صورت دستی به پروژه خود اضافه نمایید.
D8: Cannot fit requested classes in a single dex file (# methods: 68109 > 65536)
نحوهی فعالسازی MultiDex
به این ترتیب است که به آدرس Assets\Plugins\Android\launcherTemplate.gradle
بروید و کدهای زیر را به آن اضافه نمایید:
dependencies {
def multidex_version = "2.0.1"
implementation "androidx.multidex:multidex:$multidex_version" // 2.0.1
}
android {
...
defaultConfig {
...
multiDexEnabled true
}
...
}
سپس به فایل Assets\Plugins\Android\AndroidManifest.xml
مراجعه کنید و یکی از روش های الف
، ب
و ج
را مطابق پیادهسازی خود اعمال نمایید.
الف) در صورتیکه قبلا از کلاس Application
در پروژه خود استفاده نکرده اید، خط زیر را در تگ application
اضافه کنید:
<application
android:name="androidx.multidex.MultiDexApplication">
<!-- ...-->
</application>
ب) در غیر اینصورت اگر قبلا از کلاس Application
در پروژه خود استفاده کرده اید و آن را در manifest
معرفی کردهاید، وارد کلاس Application
شده و آن را از کلاس MultiDexApplication
ارث بری کنید. تغییرات مورد نیاز را همانند کد زیر اعمال کنید:
public class MainApplication extends MultiDexApplication {
// your code
}
ج) اما در صورتیکه کلاس Application
خود را از کلاس دیگری ارث بری نمودهاید و امکان ارث بری از کلاس MultiDexApplication
وجود ندارد، میتوانید متود attachBaseContext
را به صورت زیر در کلاس خود override
نمایید و تغییرات لازم را اعمال نمایید:
public class MainApplication extends SomeOtherApplication {
// your code
@Override
protected void attachBaseContext(Context base) {
super.attachBaseContext(base);
MultiDex.install(this);
}
}
برای راهنمایی بهتر میتوانید به مستندات رسمی اندروید مراجعه نمایید.
پشتیبانی از اندروید ۱۳
اپلیکیشنهایی که نسخه targetSDK
پروژه خود را به ۳۳ (اندروید ۱۳) ارتقا میدهند، باید مجوز سرویسهای گوگل پلی را در فایل مانیفست خود در مسیر Assets\Plugins\Android\AndroidManifest.xml
اضافه کنند، همانند زیر:
<uses-permission android:name="com.google.android.gms.permission.AD_ID"/>
برای خواندن بیشتر در مورد تغییرات شناسه تبلیغات گوگل اینجا کلیک کنید.
مقداردهی اولیه
ابتدا برای دسترسی به کدهای تپسل از تکه کد زیر استفاده کنید.
using TapsellPlusSDK;
سپس تابع زیر را در یکی از اسکریپتهای برنامهی خود که در ابتدای برنامه اجرا میشود فراخوانی کنید.
TapsellPlus.Initialize(TAPSELLPLUS_KEY,
adNetworkName => Debug.Log(adNetworkName + " Initialized Successfully."),
error => Debug.Log(error.ToString()));
TAPSELLPLUS_KEY
کلید تپسل پلاس هست و برای هر اپلیکیشنی که میسازید در پنل تپسل ساخته میشود و میتوانید از پنل کپی کنید.
اکنون میتوانید با توجه به نیاز خود و توضیحات به هر نوع تبلیغ، تبلیغ مورد نظر را نمایش دهید.
تنظیمات مربوط به GDPR
از آنجا که کتابخانهی تپسل پلاس قوانین GDPR را در خصوص نمایش تبلیغات شخصیسازی شده رعایت میکند، به طور پیش فرض اگر کاربر با IP یکی از کشورهای مشمول این قانون از اپلیکیشن شما استفاده کند، دیالوگی در این خصوص به کاربر نمایش میدهد. اگر تمایل دارید تا به جای تصمیم کاربر، خودتان دسترسی لازم را تعیین کنید میتوانید از تکه کد زیر استفاده نمایید. توجه داشته باشید که این تکه کد میبایستی پس از Initialize شدن تپسل پلاس و پیش از درخواست تبلیغ صدا زده شود تا نتیجهی آن در درخواست شما اعمال شده باشد. مقدار true به این معنی است که شما حق استفاده از اطلاعات جهت نمایش تبلیغ شخصیسازی شده را به شبکههای تبلیغاتی دادهاید.
TapsellPlus.SetGdprConsent(true);
Family Policy
اگر هر یک از مخاطبان هدف برنامه شما کودکان هستند (بخصوص اگر شما در حال توسعه یک بازی هستید)، محتوای برنامه شما باید مناسب برای این دسته از کاربران باشد. همچنین، امکان جمعآوری برخی از اطلاعات شخصی مانند شناسه تبلیغاتی گوگل (Google Advertising ID)
مجاز نیست. با این حال، کتابخانههای تبلیغاتی شخص ثالت نیاز به این شناسه تبلیغاتی دارند تا تبلیغات شخصیسازی را برای کاربران ارائه و ارسال کنند. پس، در کتاباخانه تبلیغاتی تپسل، تمامی کاربران به عنوان افرادی با سن 13 سال یا بالاتر در نظر گرفته میشوند. بنابراین، به عنوان یک توسعهدهنده برنامه اگر قصد انتشار برنامه خود در GooglePlay
را دارید، باید در پنل آن تایید کنید که برنامه شما برای مخاطبان با سن 13 سال یا بالاتر هدف قرار دارد. در غیر این صورت، برنامه شما بر اساس این سیاست GooglePlay
حذف خواهد شد.
پروژهی نمونه
برای راهنمایی بیشتر میتوانید از پروژههای نمونهی ما بر روی Github استفاده نمایید.