Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
A
android_goodmoney
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
android
android_goodmoney
Commits
6752303b
Commit
6752303b
authored
Apr 08, 2021
by
mengcuiguang
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'dev_mcg_reader' into dev_ad
parents
e6ac82fb
552b120c
Changes
17
Hide whitespace changes
Inline
Side-by-side
Showing
17 changed files
with
1018 additions
and
21 deletions
+1018
-21
build.gradle
GoodMoney/app/build.gradle
+66
-4
Reader17kSDK-release1.1.3.aar
GoodMoney/app/libs/Reader17kSDK-release1.1.3.aar
+0
-0
filter-lib-release1.1.aar
GoodMoney/app/libs/filter-lib-release1.1.aar
+0
-0
readerlib-release1.1.aar
GoodMoney/app/libs/readerlib-release1.1.aar
+0
-0
proguard-rules.pro
GoodMoney/app/proguard-rules.pro
+111
-1
MintsApplication.java
...p/src/main/java/com/mints/goodmoney/MintsApplication.java
+6
-0
ReaderManager.java
.../main/java/com/mints/goodmoney/manager/ReaderManager.java
+111
-0
ToutiaoAD.java
.../src/main/java/com/mints/goodmoney/manager/ToutiaoAD.java
+552
-0
TtCsjAdManager.java
...main/java/com/mints/goodmoney/manager/TtCsjAdManager.java
+1
-0
BookPresenter.kt
.../java/com/mints/goodmoney/mvp/presenters/BookPresenter.kt
+4
-4
MainActivity.kt
...ain/java/com/mints/goodmoney/ui/activitys/MainActivity.kt
+2
-0
WrapperActivity.kt
.../java/com/mints/goodmoney/ui/activitys/WrapperActivity.kt
+13
-2
BannerAdapter.java
...in/java/com/mints/goodmoney/ui/adapter/BannerAdapter.java
+1
-1
MoneyFragment.kt
...ain/java/com/mints/goodmoney/ui/fragment/MoneyFragment.kt
+22
-9
ReaderFragment.kt
...in/java/com/mints/goodmoney/ui/fragment/ReaderFragment.kt
+85
-0
item_mints_banner.xml
GoodMoney/app/src/main/res/layout/item_mints_banner.xml
+0
-0
build.gradle
GoodMoney/build.gradle
+44
-0
No files found.
GoodMoney/app/build.gradle
View file @
6752303b
...
@@ -2,6 +2,12 @@ apply plugin: 'com.android.application'
...
@@ -2,6 +2,12 @@ apply plugin: 'com.android.application'
apply
plugin:
'kotlin-android'
apply
plugin:
'kotlin-android'
apply
plugin:
'kotlin-android-extensions'
apply
plugin:
'kotlin-android-extensions'
apply
plugin:
'kotlin-kapt'
apply
plugin:
'dagger.hilt.android.plugin'
apply
plugin:
'androidx.navigation.safeargs.kotlin'
apply
plugin:
'android-aspectjx'
apply
plugin:
'com.sensorsdata.analytics.android'
android
{
android
{
compileSdkVersion
rootProject
.
ext
.
androidCompileSdkVersion
compileSdkVersion
rootProject
.
ext
.
androidCompileSdkVersion
buildToolsVersion
rootProject
.
ext
.
androidBuildToolsVersion
buildToolsVersion
rootProject
.
ext
.
androidBuildToolsVersion
...
@@ -58,6 +64,19 @@ android {
...
@@ -58,6 +64,19 @@ android {
}
}
}
}
kapt
{
arguments
{
arg
(
"AROUTER_MODULE_NAME"
,
project
.
getName
())
}
}
aspectjx
{
exclude
'versions.9'
}
buildFeatures
{
dataBinding
true
}
buildTypes
{
buildTypes
{
debug
{
debug
{
...
@@ -135,7 +154,7 @@ dependencies {
...
@@ -135,7 +154,7 @@ dependencies {
implementation
'androidx.appcompat:appcompat:1.2.0'
implementation
'androidx.appcompat:appcompat:1.2.0'
implementation
'androidx.constraintlayout:constraintlayout:1.1.3'
implementation
'androidx.constraintlayout:constraintlayout:1.1.3'
implementation
'androidx.recyclerview:recyclerview:1.0.0'
implementation
'androidx.recyclerview:recyclerview:1.0.0'
implementation
'com.google.android.material:material:1.
0
.0'
implementation
'com.google.android.material:material:1.
2
.0'
// 网络请求
// 网络请求
implementation
'com.squareup.retrofit2:retrofit:2.7.1'
implementation
'com.squareup.retrofit2:retrofit:2.7.1'
...
@@ -190,7 +209,7 @@ dependencies {
...
@@ -190,7 +209,7 @@ dependencies {
// 三方接入
// 三方接入
// leakcanary
// leakcanary
debugImplementation
'com.squareup.leakcanary:leakcanary-android:2.4'
//
debugImplementation 'com.squareup.leakcanary:leakcanary-android:2.4'
// 极光推送
// 极光推送
implementation
'cn.jiguang.sdk:jpush:3.6.6'
implementation
'cn.jiguang.sdk:jpush:3.6.6'
implementation
'cn.jiguang.sdk:jcore:2.3.8'
implementation
'cn.jiguang.sdk:jcore:2.3.8'
...
@@ -280,10 +299,53 @@ dependencies {
...
@@ -280,10 +299,53 @@ dependencies {
implementation
'com.squareup.retrofit2:converter-scalars:2.6.2'
implementation
'com.squareup.retrofit2:converter-scalars:2.6.2'
implementation
'com.squareup.retrofit2:converter-gson:2.6.2'
implementation
'com.squareup.retrofit2:converter-gson:2.6.2'
implementation
'com.alibaba:fastjson:1.2.11'
implementation
'com.alibaba:fastjson:1.2.11'
// 激励视频RTA
// 激励视频RTA
implementation
(
name:
'taskwake1.0'
,
ext:
'aar'
)
implementation
(
name:
'taskwake1.0'
,
ext:
'aar'
)
// 听读
implementation
files
(
'libs/Reader17kSDK-release1.1.3.aar'
)
implementation
files
(
'libs/readerlib-release1.1.aar'
)
implementation
files
(
'libs/filter-lib-release1.1.aar'
)
compileOnly
"com.squareup.inject:assisted-inject-annotations-dagger2:$rootProject.assistedInjectVersion"
kapt
"androidx.room:room-compiler:$rootProject.roomVersion"
kapt
"com.google.dagger:hilt-android-compiler:$rootProject.hiltVersion"
kapt
"androidx.hilt:hilt-compiler:$rootProject.hiltViewModelVersion"
kapt
"com.squareup.inject:assisted-inject-processor-dagger2:$rootProject.assistedInjectVersion"
implementation
"androidx.core:core-ktx:$rootProject.ktxVersion"
implementation
"androidx.fragment:fragment-ktx:$rootProject.fragmentVersion"
implementation
"androidx.lifecycle:lifecycle-extensions:$rootProject.lifecycleVersion"
implementation
"androidx.lifecycle:lifecycle-livedata-ktx:$rootProject.lifecycleVersion"
implementation
"androidx.lifecycle:lifecycle-viewmodel-ktx:$rootProject.lifecycleVersion"
implementation
"androidx.navigation:navigation-fragment-ktx:$rootProject.navigationVersion"
implementation
"androidx.navigation:navigation-ui-ktx:$rootProject.navigationVersion"
implementation
"androidx.paging:paging-runtime:$rootProject.pagingVersion"
implementation
"androidx.room:room-runtime:$rootProject.roomVersion"
implementation
"androidx.room:room-ktx:$rootProject.roomVersion"
implementation
"androidx.viewpager2:viewpager2:$rootProject.viewPagerVersion"
implementation
"androidx.work:work-runtime-ktx:$rootProject.workVersion"
implementation
"com.google.code.gson:gson:$rootProject.gsonVersion"
implementation
"org.jetbrains.kotlinx:kotlinx-coroutines-android:$rootProject.coroutinesVersion"
implementation
"org.jetbrains.kotlinx:kotlinx-coroutines-core:$rootProject.coroutinesVersion"
implementation
"com.google.dagger:hilt-android:$rootProject.hiltVersion"
implementation
"androidx.hilt:hilt-lifecycle-viewmodel:$rootProject.hiltViewModelVersion"
implementation
"com.scwang.smart:refresh-header-material:$rootProject.refresh_version"
implementation
'com.github.pdog18:dimension-extensions:1.0'
implementation
'com.github.zhpanvip:BannerViewPager:3.2.0'
api
"androidx.navigation:navigation-fragment-ktx:$navigationVersion"
api
"androidx.navigation:navigation-ui-ktx:$navigationVersion"
api
"androidx.navigation:navigation-dynamic-features-fragment:$navigationVersion"
implementation
'com.github.warkiz.widget:indicatorseekbar:1.2.9'
implementation
'org.greenrobot:eventbus:3.2.0'
implementation
'skin.support:skin-support:4.0.5'
implementation
'skin.support:skin-support-appcompat:4.0.5'
implementation
'skin.support:skin-support-design:4.0.5'
implementation
'skin.support:skin-support-cardview:4.0.5'
implementation
'skin.support:skin-support-constraint-layout:4.0.5'
implementation
"androidx.datastore:datastore-preferences:1.0.0-alpha02"
implementation
'com.github.F1ReKing:StatusLayout:1.2.1'
kapt
"com.alibaba:arouter-compiler:$arouter_compiler_version"
implementation
"com.alibaba:arouter-api:$arouter_api_version"
implementation
'com.sensorsdata.analytics.android:SensorsAnalyticsSDK:4.4.3'
api
'org.aspectj:aspectjrt:1.9.5'
// testImplementation 'junit:junit:4.13'
// testImplementation 'junit:junit:4.13'
// androidTestImplementation 'androidx.test.ext:junit:1.1.2'
// androidTestImplementation 'androidx.test.ext:junit:1.1.2'
...
...
GoodMoney/app/libs/Reader17kSDK-release1.1.3.aar
0 → 100755
View file @
6752303b
File added
GoodMoney/app/libs/filter-lib-release1.1.aar
0 → 100755
View file @
6752303b
File added
GoodMoney/app/libs/readerlib-release1.1.aar
0 → 100755
View file @
6752303b
File added
GoodMoney/app/proguard-rules.pro
View file @
6752303b
...
@@ -667,4 +667,114 @@
...
@@ -667,4 +667,114 @@
*
*[] $VALUES;
*
*[] $VALUES;
public *;
public *;
}
}
# ======================= 蘑菇星球 END ================
# ======================= 蘑菇星球 END ================
\ No newline at end of file
# ===================== 听读 START ================
-keep class com.chineseall.reader17ksdk.
*
*{*;}
-keep class com.chineseall.reader.utils.
*
*{*;}
-keep class com.chineseall.reader.lib.reader.
*
*{*;}
#arouter
-keep public class com.alibaba.android.arouter.routes.
*
*{*;}
-keep public class com.alibaba.android.arouter.facade.
*
*{*;}
-keep class * implements
com.alibaba.android.arouter.facade.template.ISyringe{*;}
# If you use the byType method to obtain Service, add the
-keep interface * implements
com.alibaba.android.arouter.facade.template.IProvider
#百度语音
-keep class com.baidu.tts.
*
*{*;}
-keep class com.baidu.speechsynthesizer.
*
*{*;}
#eventBus
-keepattributes *Annotation*
-keepclassmembers class
*
* {
@org.greenrobot.eventbus.Subscribe <methods>;
}
-keep enum org.greenrobot.eventbus.ThreadMode { *; }
-keep class org.greenrobot.eventbug.
*
*{*;}
-keepclassmembers class * extends
org.greenrobot.eventbus.util.ThrowableFailureEvent {
<init>(java.lang.Throwable);
}
#rxjava
-dontwarn rx.
*
*
-keep class rx.
*
* { *; }
#okhttp3
-dontwarn com.squareup.okhttp3.
*
*
-keep class com.squareup.okhttp3.
*
* { *;}
-keep class okhttp3.
*
* { *;}
-keep class okio.
*
* { *;}
-dontwarn sun.security.
*
*
-keep class sun.security.
*
* { *;}
-dontwarn okio.
*
*
-dontwarn okhttp3.
*
*
#retrofit2
-dontwarn retrofit2.
*
*
-keep class retrofit2.
*
* { *; }
-keepattributes Signature
-keepattributes Exceptions
-dontwarn org.robovm.
*
*
-keep class org.robovm.
*
* { *; }
#glide
-keep public class * implements
com.bumptech.glide.module.GlideModule
-keep public enum
com.bumptech.glide.load.resource.bitmap.ImageHeaderParser$
*
* {
*
*[] $VALUES;
public *; }
-keep class com.bumptech.glide.
*
* { *; }
#gson
-keep class com.google.gson.
*
* {*;}
#-keep class com.google.
*
*{*;}
-keep class sun.misc.Unsafe { *; }
-keep class com.google.gson.stream.
*
* { *; }
-keep class com.google.gson.examples.android.model.
*
* { *; }
-keep class com.google.
*
* {
<fields>;
<methods>; }
-keepclassmembers class * implements java.io.Serializable {
static final long serialVersionUID;
private static final java.io.ObjectStreamField[]
serialPersistentFields;
private void writeObject(java.io.ObjectOutputStream);
private void readObject(java.io.ObjectInputStream);
java.lang.Object writeReplace();
java.lang.Object readResolve();
}
-dontwarn com.google.gson.
*
*
#umeng
-dontwarn com.umeng.
*
*
-keep class com.umeng.
*
*{*;}
-keep class u.aly.
*
*{*;}
-keep class com.google.
*
*{*;}
#filter
-keep class com.baiiu.filter.
*
*{*;}
#dragger
-keep class dagger.
*
* { *; }
#statuslayout
-keep class com.f1reking.
*
*{*;}
#dp
-keep class com.pdog.dimension.
*
*{*;}
#seekbar
-keep class com.warkiz.widget.
*
*{*;}
#banner
-keep class com.zhpan.bannerview.
*
*{*;}
-keep class com.zhpan.indicator.
*
*{*;}
#refresh
-keep class com.scwang.smart.refresh.
*
*{*;}
#skin
-keep class skin.support.
*
*{*;}
#神策
-dontwarn com.sensorsdata.analytics.android.sdk.
*
* -keep class com.sensorsdata.analytics.android.sdk.
*
* { *;
}
-dontwarn com.sensorsdata.analytics.android.
*
*
-keep class com.sensorsdata.analytics.android.
*
* {
*;
}
# 使用可视化埋点需添加
-keep class
*
*.R$* {
<fields>; }
# ======================= 听读 END ================
\ No newline at end of file
GoodMoney/app/src/main/java/com/mints/goodmoney/MintsApplication.java
View file @
6752303b
...
@@ -16,6 +16,7 @@ import com.mints.goodmoney.manager.KsManager;
...
@@ -16,6 +16,7 @@ import com.mints.goodmoney.manager.KsManager;
import
com.mints.goodmoney.manager.LiebaoManager
;
import
com.mints.goodmoney.manager.LiebaoManager
;
import
com.mints.goodmoney.manager.MhManager
;
import
com.mints.goodmoney.manager.MhManager
;
import
com.mints.goodmoney.manager.MiitHelper
;
import
com.mints.goodmoney.manager.MiitHelper
;
import
com.mints.goodmoney.manager.ReaderManager
;
import
com.mints.goodmoney.manager.RsNewsManager
;
import
com.mints.goodmoney.manager.RsNewsManager
;
import
com.mints.goodmoney.manager.TtCsjAdManager
;
import
com.mints.goodmoney.manager.TtCsjAdManager
;
import
com.mints.goodmoney.manager.TzManager
;
import
com.mints.goodmoney.manager.TzManager
;
...
@@ -41,6 +42,7 @@ import com.ximalaya.ting.android.opensdk.util.BaseUtil;
...
@@ -41,6 +42,7 @@ import com.ximalaya.ting.android.opensdk.util.BaseUtil;
import
java.util.concurrent.Executors
;
import
java.util.concurrent.Executors
;
import
dagger.hilt.android.HiltAndroidApp
;
import
rx.Scheduler
;
import
rx.Scheduler
;
import
rx.schedulers.Schedulers
;
import
rx.schedulers.Schedulers
;
...
@@ -49,6 +51,7 @@ import rx.schedulers.Schedulers;
...
@@ -49,6 +51,7 @@ import rx.schedulers.Schedulers;
* 作者:孟崔广
* 作者:孟崔广
* 时间:2020/10/09 11:40
* 时间:2020/10/09 11:40
*/
*/
@HiltAndroidApp
public
class
MintsApplication
extends
MultiDexApplication
{
public
class
MintsApplication
extends
MultiDexApplication
{
private
static
MintsApplication
mContext
;
private
static
MintsApplication
mContext
;
...
@@ -146,6 +149,9 @@ public class MintsApplication extends MultiDexApplication {
...
@@ -146,6 +149,9 @@ public class MintsApplication extends MultiDexApplication {
// 自定义logger
// 自定义logger
bindLogger
();
bindLogger
();
// 中文在线 听读
ReaderManager
.
init
(
this
);
// 子线程初始化三方SDK
// 子线程初始化三方SDK
String
processName
=
SystemUtils
.
INSTANCE
.
getProcessName
(
this
,
android
.
os
.
Process
.
myPid
());
String
processName
=
SystemUtils
.
INSTANCE
.
getProcessName
(
this
,
android
.
os
.
Process
.
myPid
());
...
...
GoodMoney/app/src/main/java/com/mints/goodmoney/manager/ReaderManager.java
0 → 100644
View file @
6752303b
package
com
.
mints
.
goodmoney
.
manager
;
import
android.app.Application
;
import
android.app.Dialog
;
import
android.content.DialogInterface
;
import
android.view.View
;
import
androidx.appcompat.app.AlertDialog
;
import
com.chineseall.reader.lib.reader.callbacks.OnAdViewReceiver
;
import
com.chineseall.reader17ksdk.ChineseAllReaderApplication
;
import
com.chineseall.reader17ksdk.callbacks.AdProvider
;
import
com.chineseall.reader17ksdk.callbacks.OnReadCallBack
;
import
com.chineseall.reader17ksdk.utils.ActivityStackManager
;
import
com.chineseall.reader17ksdk.utils.DensityUtil
;
import
com.chineseall.reader17ksdk.utils.NetworkUtil
;
import
com.chineseall.reader17ksdk.utils.ToastUtil
;
import
com.chineseall.reader17ksdk.utils.book.ScreenUtils
;
import
org.jetbrains.annotations.NotNull
;
import
org.jetbrains.annotations.Nullable
;
import
java.util.Map
;
import
kotlin.Unit
;
import
kotlin.jvm.functions.Function0
;
/**
* 中文在线 听读
* 作者:孟崔广
* 时间:2021/04/08 14:44
* 邮箱:mengcga@163.com
*/
public
class
ReaderManager
{
public
static
void
init
(
Application
applicationContext
)
{
ToutiaoAD
csjAd
=
new
ToutiaoAD
();
ChineseAllReaderApplication
.
Companion
.
install
(
applicationContext
,
"1242"
,
"hzq@1242"
,
"32"
,
"0"
,
new
AdProvider
()
{
/**
* 阅读⻚弹窗广告确认按钮的点击回调-激励视频
* @param dialog
* @param block 对话框关闭回调,必须调用,否则计时每次切换章节都会出现弹窗
*/
@Override
public
void
onAdDialogPositiveClick
(
@Nullable
Dialog
dialog
,
@NotNull
Function0
<
Unit
>
function0
)
{
if
(
NetworkUtil
.
isNetworkAvailable
(
applicationContext
)
&&
!
NetworkUtil
.
INSTANCE
.
isWifiConnected
(
applicationContext
))
{
new
AlertDialog
.
Builder
(
ActivityStackManager
.
getInstance
().
getTopActivity
())
.
setTitle
(
"温馨提示"
)
.
setMessage
(
"当前处于移动网络,播放视频会消耗流量,确定播放?"
)
.
setPositiveButton
(
"观看视频"
,
new
DialogInterface
.
OnClickListener
()
{
@Override
public
void
onClick
(
DialogInterface
dialog
,
int
which
)
{
csjAd
.
showVideo
(
ActivityStackManager
.
getInstance
().
getTopActivity
(),
new
ToutiaoAD
.
OnVideoCloseCallBack
()
{
@Override
public
void
onClose
()
{
function0
.
invoke
();
}
});
}
}).
setNegativeButton
(
"取消"
,
new
DialogInterface
.
OnClickListener
()
{
@Override
public
void
onClick
(
DialogInterface
dialog
,
int
which
)
{
dialog
.
dismiss
();
}
}).
create
().
show
();
return
;
}
else
{
csjAd
.
showVideo
(
ActivityStackManager
.
getInstance
().
getTopActivity
(),
new
ToutiaoAD
.
OnVideoCloseCallBack
()
{
@Override
public
void
onClose
()
{
function0
.
invoke
();
}
});
}
}
/**
* 阅读⻚首次打开 弹框广告(信息流) 广告宽度 320 高度 260 * @param adViewContainer 广告view的容器
*/
@Override
public
void
getReaderScreenAd
(
@NotNull
View
view
,
@NotNull
OnAdViewReceiver
receiver
,
@Nullable
Dialog
dialog
)
{
csjAd
.
loadAD
(
applicationContext
,
receiver
,
320
,
260
,
new
ToutiaoAD
.
OnClickListener
()
{
@Override
public
void
onClick
()
{
dialog
.
dismiss
();
}
});
}
/**
* 阅读⻚翻⻚广告(信息流) 广告宽度 320 高度 260 */
@Override
public
void
getReaderPageAd
(
@NotNull
OnAdViewReceiver
receiver
)
{
csjAd
.
loadAD
(
applicationContext
,
receiver
,
DensityUtil
.
px2dip
(
applicationContext
,
ScreenUtils
.
getScreenWidth
(
applicationContext
)
-
DensityUtil
.
dip2px
(
applicationContext
,
30
f
)),
DensityUtil
.
px2dip
(
applicationContext
,
854
f
),
null
);
}
/**
* 阅读⻚定时弹窗广告 (激励视频)
*/
@Override
public
void
getReaderDialogAd
(
@NotNull
View
view
,
@NotNull
OnAdViewReceiver
receiver
,
@Nullable
Dialog
dialog
)
{
csjAd
.
loadVideoAd
(
ActivityStackManager
.
getInstance
().
getTopActivity
(),
receiver
);
}
});
}
}
GoodMoney/app/src/main/java/com/mints/goodmoney/manager/ToutiaoAD.java
0 → 100755
View file @
6752303b
package
com
.
mints
.
goodmoney
.
manager
;
import
android.app.Activity
;
import
android.content.Context
;
import
android.view.View
;
import
android.widget.Toast
;
import
com.bytedance.sdk.openadsdk.AdSlot
;
import
com.bytedance.sdk.openadsdk.TTAdConstant
;
import
com.bytedance.sdk.openadsdk.TTAdNative
;
import
com.bytedance.sdk.openadsdk.TTAdSdk
;
import
com.bytedance.sdk.openadsdk.TTAppDownloadListener
;
import
com.bytedance.sdk.openadsdk.TTFeedAd
;
import
com.bytedance.sdk.openadsdk.TTImage
;
import
com.bytedance.sdk.openadsdk.TTNativeExpressAd
;
import
com.bytedance.sdk.openadsdk.TTRewardVideoAd
;
import
com.chineseall.reader.lib.reader.callbacks.OnAdViewReceiver
;
import
com.chineseall.reader17ksdk.ChineseAllReaderApplication
;
import
com.chineseall.reader17ksdk.aop.AspectTest
;
import
com.chineseall.reader17ksdk.utils.LogUtils
;
import
com.chineseall.reader17ksdk.utils.book.ScreenUtils
;
import
com.mints.library.utils.json.JsonUtil
;
import
java.util.List
;
public
class
ToutiaoAD
{
private
static
final
String
tag
=
"ToutiaoAD"
;
/*
开屏和信息流都用此
*/
//开屏广告加载超时时间,建议大于200
private
static
final
int
AD_TIME_OUT
=
3000
;
private
TTAdNative
mTTAdNative
;
private
Context
context
;
private
TTFeedAd
feedAd
;
//信息流回调类
private
TTRewardVideoAd
mttRewardVideoAd
;
private
View
mView
;
public
String
getIcon
()
{
if
(
feedAd
==
null
)
{
return
null
;
}
TTImage
ttImage
=
feedAd
.
getIcon
();
if
(
ttImage
!=
null
&&
ttImage
.
getImageUrl
()
!=
null
)
{
return
ttImage
.
getImageUrl
();
}
return
null
;
}
public
String
getImage
()
{
if
(
feedAd
==
null
)
{
return
null
;
}
List
<
TTImage
>
list
=
feedAd
.
getImageList
();
if
(
list
!=
null
&&
list
.
size
()
>
0
)
{
TTImage
ttImage
=
list
.
get
(
0
);
if
(
ttImage
!=
null
&&
ttImage
.
getImageUrl
()
!=
null
)
{
return
ttImage
.
getImageUrl
();
}
}
return
null
;
}
public
String
getTitle
()
{
if
(
feedAd
==
null
)
{
return
null
;
}
return
feedAd
.
getTitle
();
}
public
String
getDesc
()
{
if
(
feedAd
==
null
)
{
return
null
;
}
return
feedAd
.
getDescription
();
}
public
String
getUrl
()
{
return
null
;
}
public
boolean
isApp
()
{
return
false
;
}
public
View
getView
()
{
return
mView
;
}
public
List
<
String
>
getImageList
()
{
return
null
;
}
// @Override
public
void
loadAD
(
final
Context
context
,
OnAdViewReceiver
receiver
,
int
width
,
int
height
,
OnClickListener
listener
)
{
this
.
context
=
context
;
LogUtils
.
d
(
tag
,
"load ad"
);
if
(
mTTAdNative
==
null
)
{
mTTAdNative
=
TtCsjAdManager
.
get
().
createAdNative
(
context
);
}
// if (ADConfig.TYPE_NATIVE.equals(adParamers.type)){
//信息流
// initNativeAD();
// }else if(ADConfig.TYPE_SPLASH.equals(adParamers.type)){
// 开屏
// initSplashAD();
// }else if(ADConfig.TYPE_INTERSTITIAL.equals(adParamers.type)){
//插屏广告
// initInteractionAD((Activity) context);
// }else if (ADConfig.TYPE_VIDEO.equals(adParamers.type)){
// initVedioAD(context);
// }else if (ADConfig.TYPE_FEED.equals(adParamers.type)){
initFeedAD
(
receiver
,
width
,
height
,
listener
);
// }
}
public
void
loadVideoAd
(
Context
context
,
OnAdViewReceiver
receiver
)
{
this
.
context
=
context
;
if
(
mTTAdNative
==
null
)
{
mTTAdNative
=
TtCsjAdManager
.
get
().
createAdNative
(
context
);
}
initVedioAD
(
context
,
receiver
);
}
private
void
initFeedAD
(
OnAdViewReceiver
receiver
,
int
width
,
int
height
,
OnClickListener
clickListener
)
{
// DensityUtil.px2dip(context, ScreenUtils.getScreenWidth(context) - DensityUtil.dip2px(context, 30)), DensityUtil.px2dip(context, 854)
//设置广告参数
AdSlot
adSlot
=
new
AdSlot
.
Builder
()
.
setCodeId
(
TtCsjAdManager
.
TT_AD_NATIVEEXPRESS_WALK
)
//广告位id
.
setSupportDeepLink
(
true
)
.
setAdCount
(
1
)
//请求广告数量为1到3条
.
setExpressViewAcceptedSize
(
width
,
height
)
//必填:期望个性化模板广告view的size,单位dp
.
setImageAcceptedSize
(
400
,
150
)
//这个参数设置即可,不影响个性化模板广告的size
.
build
();
mTTAdNative
.
loadNativeExpressAd
(
adSlot
,
new
TTAdNative
.
NativeExpressAdListener
()
{
@Override
public
void
onError
(
int
code
,
String
message
)
{
LogUtils
.
d
(
tag
,
"code: "
+
code
+
", "
+
message
);
receiver
.
onReceive
(
false
,
null
);
// TToast.show(NativeExpressActivity.this, "load error : " + code + ", " + message);
// getAdParamers().parent.removeAllViews();
}
@Override
public
void
onNativeExpressAdLoad
(
List
<
TTNativeExpressAd
>
ads
)
{
if
(
ads
==
null
||
ads
.
size
()
==
0
)
{
return
;
}
LogUtils
.
d
(
tag
,
"onNativeExpressAdLoad : "
+
ads
.
size
());
TTNativeExpressAd
mTTAd
=
ads
.
get
(
0
);
bindAdListener
(
mTTAd
,
receiver
,
clickListener
);
mTTAd
.
render
();
//调用render开始渲染广告
}
});
}
//绑定广告行为
private
void
bindAdListener
(
TTNativeExpressAd
ad
,
OnAdViewReceiver
receiver
,
OnClickListener
clickListener
)
{
ad
.
setExpressInteractionListener
(
new
TTNativeExpressAd
.
ExpressAdInteractionListener
()
{
@Override
public
void
onAdClicked
(
View
view
,
int
type
)
{
LogUtils
.
d
(
tag
,
"onAdClicked : "
+
type
);
LogUtils
.
d
(
"onAdClicked"
);
if
(
clickListener
!=
null
)
{
clickListener
.
onClick
();
}
}
@Override
public
void
onAdShow
(
View
view
,
int
type
)
{
LogUtils
.
d
(
tag
,
"onAdShow : "
+
type
);
LogUtils
.
d
(
"onAdShow"
);
}
@Override
public
void
onRenderFail
(
View
view
,
String
msg
,
int
code
)
{
LogUtils
.
d
(
tag
,
"onRenderFail : "
+
msg
+
", "
+
code
);
receiver
.
onReceive
(
false
,
view
);
}
@Override
public
void
onRenderSuccess
(
View
view
,
float
width
,
float
height
)
{
LogUtils
.
d
(
tag
,
"onRenderSuccess : "
+
view
.
getClass
().
getName
());
//返回view的宽高 单位 dp
//在渲染成功回调时展示广告,提升体验
// getAdParamers().parent.removeAllViews();
// getAdParamers().parent.addView(view);
mView
=
view
;
if
(
mView
!=
null
&&
!
AspectTest
.
views
.
contains
(
view
.
getClass
().
getName
()))
{
AspectTest
.
views
.
add
(
view
.
getClass
().
getName
());
}
receiver
.
onReceive
(
true
,
view
);
// adParamers.listener.onADLoaded(com.rice.gluepudding.ad.impl.ToutiaoAD.this);
}
});
//dislike设置
// bindDislike(ad, false);
if
(
ad
.
getInteractionType
()
!=
TTAdConstant
.
INTERACTION_TYPE_DOWNLOAD
)
{
return
;
}
//可选,下载监听设置
ad
.
setDownloadListener
(
new
TTAppDownloadListener
()
{
@Override
public
void
onIdle
()
{
LogUtils
.
d
(
tag
,
"onIdle : "
);
// TToast.show(NativeExpressActivity.this, "点击开始下载", Toast.LENGTH_LONG);
}
@Override
public
void
onDownloadActive
(
long
totalBytes
,
long
currBytes
,
String
fileName
,
String
appName
)
{
LogUtils
.
d
(
tag
,
"onDownloadActive : "
);
// if (!mHasShowDownloadActive) {
// mHasShowDownloadActive = true;
// TToast.show(NativeExpressActivity.this, "下载中,点击暂停", Toast.LENGTH_LONG);
// }
}
@Override
public
void
onDownloadPaused
(
long
totalBytes
,
long
currBytes
,
String
fileName
,
String
appName
)
{
LogUtils
.
d
(
tag
,
"onDownloadPaused : "
);
// TToast.show(NativeExpressActivity.this, "下载暂停,点击继续", Toast.LENGTH_LONG);
}
@Override
public
void
onDownloadFailed
(
long
totalBytes
,
long
currBytes
,
String
fileName
,
String
appName
)
{
LogUtils
.
d
(
tag
,
"onDownloadFailed : "
);
// TToast.show(NativeExpressActivity.this, "下载失败,点击重新下载", Toast.LENGTH_LONG);
}
@Override
public
void
onInstalled
(
String
fileName
,
String
appName
)
{
LogUtils
.
d
(
tag
,
"onInstalled : "
);
// TToast.show(NativeExpressActivity.this, "安装完成,点击图片打开", Toast.LENGTH_LONG);
}
@Override
public
void
onDownloadFinished
(
long
totalBytes
,
String
fileName
,
String
appName
)
{
LogUtils
.
d
(
tag
,
"onDownloadFinished : "
);
// TToast.show(NativeExpressActivity.this, "点击安装", Toast.LENGTH_LONG);
}
});
}
private
void
initVedioAD
(
final
Context
context
,
OnAdViewReceiver
receiver
)
{
// SharedPreferencesUtil.getInstance().putBoolean(StringConstants.VIDEO_TASK_FINISH, false);
AdSlot
adSlot
=
new
AdSlot
.
Builder
()
.
setCodeId
(
TtCsjAdManager
.
TT_AD_VEDIO_READ
)
.
setSupportDeepLink
(
true
)
//个性化模板广告需要设置期望个性化模板广告的大小,单位dp,激励视频场景,只要设置的值大于0即可。仅模板广告需要设置此参数
.
setExpressViewAcceptedSize
(
500
,
500
)
.
setImageAcceptedSize
(
1080
,
1920
)
.
setUserID
(
UserManager
.
getInstance
().
getUserID
())
//用户id,必传参数
.
setMediaExtra
(
"media_extra"
)
.
setOrientation
(
TTAdConstant
.
VERTICAL
)
.
build
();
mTTAdNative
.
loadRewardVideoAd
(
adSlot
,
new
TTAdNative
.
RewardVideoAdListener
()
{
@Override
public
void
onError
(
int
code
,
String
message
)
{
LogUtils
.
i
(
"ToutiaoAd"
,
message
);
// adParamers.listener.onAdFailed("error");
receiver
.
onReceive
(
false
,
null
);
}
//视频广告加载后的视频文件资源缓存到本地的回调
@Override
public
void
onRewardVideoCached
()
{
LogUtils
.
i
(
"ToutiaoAd"
,
"rewardVideoAd video cached"
);
}
//视频广告素材加载到,如title,视频url等,不包括视频文件
@Override
public
void
onRewardVideoAdLoad
(
TTRewardVideoAd
ad
)
{
// Log.i("ToutiaoAd","rewardVideoAd loaded");
mttRewardVideoAd
=
ad
;
receiver
.
onReceive
(
true
,
null
);
//mttRewardVideoAd.setShowDownLoadBar(false);
}
});
}
public
void
showVideo
(
Context
context
,
OnVideoCloseCallBack
callBack
)
{
if
(
mttRewardVideoAd
!=
null
)
{
mttRewardVideoAd
.
setRewardAdInteractionListener
(
new
TTRewardVideoAd
.
RewardAdInteractionListener
()
{
@Override
public
void
onAdShow
()
{
LogUtils
.
i
(
"ToutiaoAd"
,
"rewardVideoAd onAdShow"
);
// adParamers.listener.onADLoaded(com.rice.gluepudding.ad.impl.ToutiaoAD.this);
}
@Override
public
void
onAdVideoBarClick
()
{
LogUtils
.
i
(
"ToutiaoAd"
,
"rewardVideoAd onAdVideoBarClick"
);
// adParamers.listener.onAdClick();
}
@Override
public
void
onAdClose
()
{
LogUtils
.
i
(
"ToutiaoAd"
,
"rewardVideoAd onAdClose"
);
if
(
callBack
!=
null
)
{
callBack
.
onClose
();
}
// adParamers.listener.onAdDismiss();
// EventBus.getDefault().post(new ADCloseEvent(SharedPreferencesUtil.getInstance().getInt(StringConstants.LOOK_VEDIO_TYPE, LOOK_VEDIO_AD_TYPE.NORMAL)));
}
@Override
public
void
onVideoComplete
()
{
LogUtils
.
i
(
"ToutiaoAd"
,
"rewardVideoAd complete"
);
// Toast.makeText(context,"恭喜您,观看完毕!",Toast.LENGTH_SHORT).show();
}
@Override
public
void
onVideoError
()
{
LogUtils
.
i
(
"ToutiaoAd"
,
"rewardVideoAd onVideoError"
);
// if (com.burst.ad_toutiao_lib.BuildConfig.DEBUG){
Toast
.
makeText
(
context
,
"视频播放错误"
,
Toast
.
LENGTH_SHORT
).
show
();
// }
}
@Override
public
void
onRewardVerify
(
boolean
b
,
int
i
,
String
s
,
int
i1
,
String
s1
)
{
}
@Override
public
void
onSkippedVideo
()
{
}
});
mttRewardVideoAd
.
setDownloadListener
(
new
TTAppDownloadListener
()
{
@Override
public
void
onIdle
()
{
}
@Override
public
void
onDownloadActive
(
long
totalBytes
,
long
currBytes
,
String
fileName
,
String
appName
)
{
}
@Override
public
void
onDownloadPaused
(
long
totalBytes
,
long
currBytes
,
String
fileName
,
String
appName
)
{
}
@Override
public
void
onDownloadFailed
(
long
totalBytes
,
long
currBytes
,
String
fileName
,
String
appName
)
{
}
@Override
public
void
onDownloadFinished
(
long
totalBytes
,
String
fileName
,
String
appName
)
{
}
@Override
public
void
onInstalled
(
String
fileName
,
String
appName
)
{
}
});
mttRewardVideoAd
.
showRewardVideoAd
((
Activity
)
context
);
}
}
public
interface
OnVideoCloseCallBack
{
void
onClose
();
}
public
interface
OnClickListener
{
void
onClick
();
}
// private void initInteractionAD(final Activity context) {
// //插屏广告请求类型数据
// AdSlot adSlot = new AdSlot.Builder()
// .setCodeId(adParamers.key)
// .setSupportDeepLink(true)
// .setImageAcceptedSize(600, 600)
// .build();
// //调用插屏广告异步请求接口
// mTTAdNative.loadInteractionAd(adSlot, new TTAdNative.InteractionAdListener() {
// @Override
// public void onError(int i, String s) {
//
// }
//
// @Override
// public void onInteractionAdLoad(TTInteractionAd ttInteractionAd) {
// ttInteractionAd.setAdInteractionListener(new TTInteractionAd.AdInteractionListener() {
// @Override
// public void onAdClicked() {
// adParamers.listener.onAdClick();
// }
//
// @Override
// public void onAdShow() {
// adParamers.listener.onADLoaded(com.rice.gluepudding.ad.impl.ToutiaoAD.this);
// }
//
// @Override
// public void onAdDismiss() {
//
// }
// });
// //弹出插屏广告
// ttInteractionAd.showInteractionAd(context);
// }
// });
// }
//
// private void initSplashAD() {
// //开屏广告参数
// AdSlot adSlot = new AdSlot.Builder()
// .setCodeId(adParamers.key)
// .setSupportDeepLink(true)
// .setImageAcceptedSize(ScreenUtils.getScreenWidth(), ScreenUtils.getScreenHeight())
// .build();
// mTTAdNative.loadSplashAd(adSlot, new TTAdNative.SplashAdListener() {
// @Override
// public void onError(int code, String message) {
// //开屏广告请求失败
// adParamers.listener.onAdFailed(message);
// }
//
// @Override
// public void onTimeout() {
// //开屏广告请求超时
// adParamers.listener.onAdFailed("请求超时了");
// }
//
// @Override
// public void onSplashAdLoad(TTSplashAd ttSplashAd) {
//
// //开屏广告请求成功了
// if(ttSplashAd == null){
// return;
// }
//
// adParamers.listener.onADLoaded(com.rice.gluepudding.ad.impl.ToutiaoAD.this);
//
// //获取SplashView
// View view = ttSplashAd.getSplashView();
// adParamers.parent.removeAllViews();
// //把SplashView 添加到ViewGroup中
// adParamers.parent.addView(view);
//
// //设置不显示SDK自带的跳过和倒计时
// ttSplashAd.setNotAllowSdkCountdown();
//
// ttSplashAd.setSplashInteractionListener(new TTSplashAd.AdInteractionListener() {
// @Override
// public void onAdClicked(View view, int i) {
// //广告点击了
// adParamers.listener.onAdClick();
// }
//
// @Override
// public void onAdShow(View view, int i) {
// //广告显示了
//// adParamers.listener.onADLoaded(ToutiaoAD.this);
// }
//
// @Override
// public void onAdSkip() {
// //广告跳过
// adParamers.listener.onAdDismiss();
// }
//
// @Override
// public void onAdTimeOver() {
// //开屏广告倒计时结束
// adParamers.listener.onAdDismiss();
// }
// });
// }
// },AD_TIME_OUT);
// }
// private void initNativeAD() {
// //feed广告请求类型参数
// AdSlot adSlot = new AdSlot.Builder()
// .setCodeId(adParamers.key)
// .setSupportDeepLink(true)
// .setImageAcceptedSize(640, 320)
// .setAdCount(1)
// .build();
// mTTAdNative.loadFeedAd(adSlot, new TTAdNative.FeedAdListener() {
// @Override
// public void onError(int code, String message) {
// adParamers.listener.onAdFailed(message);
// }
//
// @Override
// public void onFeedAdLoad(List<TTFeedAd> ads) {
// if(ads != null && ads.size() > 0){
// feedAd = ads.get(0);
// adParamers.listener.onADLoaded(com.rice.gluepudding.ad.impl.ToutiaoAD.this);
// }else{
// adParamers.listener.onAdFailed("没有广告");
// }
// }
// });
// }
// @Override
public
boolean
onExposured
(
View
view
)
{
// if (ADConfig.TYPE_NATIVE.equals(adParamers.type)){
//
// if(feedAd != null){
// feedAd.registerViewForInteraction(adParamers.parent, adParamers.clickViewList, null, new TTNativeAd.AdInteractionListener() {
// @Override
// public void onAdClicked(View view, TTNativeAd ttNativeAd) {
//// adParamers.listener.onAdClick();
// }
//
// @Override
// public void onAdCreativeClick(View view, TTNativeAd ttNativeAd) {
//
// }
//
// @Override
// public void onAdShow(TTNativeAd ttNativeAd) {
// if(ttNativeAd != null){
// //广告显示了
//// adParamers.listener.onAdShow(com.rice.gluepudding.ad.impl.ToutiaoAD.this);
// }
// }
// });
//
// }
// }
return
false
;
}
// @Override
public
boolean
onClicked
(
View
view
)
{
return
false
;
}
}
GoodMoney/app/src/main/java/com/mints/goodmoney/manager/TtCsjAdManager.java
View file @
6752303b
...
@@ -43,6 +43,7 @@ public class TtCsjAdManager {
...
@@ -43,6 +43,7 @@ public class TtCsjAdManager {
public
static
String
TT_AD_VEDIO_HOMEVEDIO
=
"945744137"
;
// 首页视频翻倍
public
static
String
TT_AD_VEDIO_HOMEVEDIO
=
"945744137"
;
// 首页视频翻倍
public
static
String
TT_AD_VEDIO_SMALLHOMEVEDIO
=
"945744186"
;
// 短视频翻倍
public
static
String
TT_AD_VEDIO_SMALLHOMEVEDIO
=
"945744186"
;
// 短视频翻倍
public
static
String
TT_AD_VEDIO_KYLVEDIO
=
"945791766"
;
// 来电秀视频
public
static
String
TT_AD_VEDIO_KYLVEDIO
=
"945791766"
;
// 来电秀视频
public
static
String
TT_AD_VEDIO_READ
=
"945997554"
;
// 听读
/*全屏视频*/
/*全屏视频*/
public
static
String
TT_AD_FULLVEDIO_ALL
=
"945752969"
;
// 通用
public
static
String
TT_AD_FULLVEDIO_ALL
=
"945752969"
;
// 通用
/*信息流*/
/*信息流*/
...
...
GoodMoney/app/src/main/java/com/mints/goodmoney/mvp/presenters/BookPresenter.kt
View file @
6752303b
...
@@ -28,10 +28,10 @@ class BookPresenter : BasePresenter<BookView>() {
...
@@ -28,10 +28,10 @@ class BookPresenter : BasePresenter<BookView>() {
val
data
=
baseResponse
.
data
val
data
=
baseResponse
.
data
when
(
code
)
{
when
(
code
)
{
200
->
{
200
->
{
if
(
data
!=
null
)
{
//
if (data != null) {
val
coin
=
data
[
"coin"
].
asInt
//
val coin = data["coin"].asInt
view
.
readSecondsSuc
(
coin
)
//
view.readSecondsSuc(coin)
}
//
}
}
}
else
->
view
.
showToast
(
baseResponse
.
getMessage
())
else
->
view
.
showToast
(
baseResponse
.
getMessage
())
}
}
...
...
GoodMoney/app/src/main/java/com/mints/goodmoney/ui/activitys/MainActivity.kt
View file @
6752303b
...
@@ -20,6 +20,7 @@ import com.mints.goodmoney.manager.UserManager
...
@@ -20,6 +20,7 @@ import com.mints.goodmoney.manager.UserManager
import
com.mints.goodmoney.mvp.views.MainView
import
com.mints.goodmoney.mvp.views.MainView
import
com.mints.goodmoney.ui.activitys.base.BaseActivity
import
com.mints.goodmoney.ui.activitys.base.BaseActivity
import
com.mints.goodmoney.ui.fragment.*
import
com.mints.goodmoney.ui.fragment.*
import
dagger.hilt.android.AndroidEntryPoint
import
kotlinx.android.synthetic.main.activity_main.*
import
kotlinx.android.synthetic.main.activity_main.*
/**
/**
...
@@ -28,6 +29,7 @@ import kotlinx.android.synthetic.main.activity_main.*
...
@@ -28,6 +29,7 @@ import kotlinx.android.synthetic.main.activity_main.*
* 时间:2020/10/9 10:39
* 时间:2020/10/9 10:39
* 邮箱:mengcga@163.com
* 邮箱:mengcga@163.com
*/
*/
@AndroidEntryPoint
class
MainActivity
:
BaseActivity
(),
MainView
,
View
.
OnClickListener
{
class
MainActivity
:
BaseActivity
(),
MainView
,
View
.
OnClickListener
{
private
val
audioManager
by
lazy
{
getSystemService
(
Context
.
AUDIO_SERVICE
)
as
AudioManager
}
private
val
audioManager
by
lazy
{
getSystemService
(
Context
.
AUDIO_SERVICE
)
as
AudioManager
}
...
...
GoodMoney/app/src/main/java/com/mints/goodmoney/ui/activitys/WrapperActivity.kt
View file @
6752303b
...
@@ -3,12 +3,14 @@ package com.mints.goodmoney.ui.activitys
...
@@ -3,12 +3,14 @@ package com.mints.goodmoney.ui.activitys
import
android.os.Bundle
import
android.os.Bundle
import
android.view.View
import
android.view.View
import
androidx.fragment.app.Fragment
import
androidx.fragment.app.Fragment
import
com.fly.scenemodule.fragment.IdiomFragment
import
androidx.fragment.app.FragmentTransaction
import
com.chineseall.reader17ksdk.feature.main.bookshop.wellchosen.WellChosenFragment
import
com.mints.goodmoney.R
import
com.mints.goodmoney.R
import
com.mints.goodmoney.common.Constant
import
com.mints.goodmoney.common.Constant
import
com.mints.goodmoney.ui.activitys.base.BaseActivity
import
com.mints.goodmoney.ui.activitys.base.BaseActivity
import
com.mints.goodmoney.ui.fragment.*
import
com.mints.goodmoney.ui.fragment.*
import
com.mints.goodmoney.ui.widgets.seekbar.BubbleUtils
import
com.mints.goodmoney.ui.widgets.seekbar.BubbleUtils
import
dagger.hilt.android.AndroidEntryPoint
import
kotlinx.android.synthetic.main.activity_wrapper.*
import
kotlinx.android.synthetic.main.activity_wrapper.*
import
kotlinx.android.synthetic.main.header_layout.*
import
kotlinx.android.synthetic.main.header_layout.*
...
@@ -55,6 +57,15 @@ class WrapperActivity : BaseActivity(), View.OnClickListener {
...
@@ -55,6 +57,15 @@ class WrapperActivity : BaseActivity(), View.OnClickListener {
layoutParams
.
height
=
BubbleUtils
.
dp2px
(
30
)
layoutParams
.
height
=
BubbleUtils
.
dp2px
(
30
)
tv_title
.
text
=
"新闻"
tv_title
.
text
=
"新闻"
currentFragment
=
RsNewsFragment
()
currentFragment
=
RsNewsFragment
()
// val wellChosenFragment = WellChosenFragment("home")
// val transaction = supportFragmentManager.beginTransaction()
// transaction.add(R.id.flWrapper, wellChosenFragment, WellChosenFragment::class.java.toString())
// transaction.show(wellChosenFragment)
// transaction.commitAllowingStateLoss()
}
Constant
.
WRAPPER_TYPE_BOOK
->
{
tv_title
.
text
=
"书城"
currentFragment
=
ReaderFragment
()
}
}
Constant
.
WRAPPER_TYPE_FRIENDS
->
{
Constant
.
WRAPPER_TYPE_FRIENDS
->
{
tv_title
.
text
=
"瓜分百万现金福利"
tv_title
.
text
=
"瓜分百万现金福利"
...
@@ -77,7 +88,7 @@ class WrapperActivity : BaseActivity(), View.OnClickListener {
...
@@ -77,7 +88,7 @@ class WrapperActivity : BaseActivity(), View.OnClickListener {
if
(!
currentFragment
.
isAdded
)
{
if
(!
currentFragment
.
isAdded
)
{
// 提交事务
// 提交事务
supportFragmentManager
.
beginTransaction
()
supportFragmentManager
.
beginTransaction
()
.
add
(
R
.
id
.
flWrapper
,
currentFragment
).
commitAllowingStateLoss
()
.
add
(
R
.
id
.
flWrapper
,
currentFragment
,
currentFragment
.
tag
).
commitAllowingStateLoss
()
}
}
}
}
...
...
GoodMoney/app/src/main/java/com/mints/goodmoney/ui/adapter/BannerAdapter.java
View file @
6752303b
...
@@ -26,7 +26,7 @@ public class BannerAdapter extends BannerBaseAdapter<BannerBean.ListBean> {
...
@@ -26,7 +26,7 @@ public class BannerAdapter extends BannerBaseAdapter<BannerBean.ListBean> {
@Override
@Override
protected
int
getLayoutResID
()
{
protected
int
getLayoutResID
()
{
return
R
.
layout
.
item_banner
;
return
R
.
layout
.
item_
mints_
banner
;
}
}
@Override
@Override
...
...
GoodMoney/app/src/main/java/com/mints/goodmoney/ui/fragment/MoneyFragment.kt
View file @
6752303b
...
@@ -4,9 +4,11 @@ import androidx.fragment.app.Fragment
...
@@ -4,9 +4,11 @@ import androidx.fragment.app.Fragment
import
androidx.fragment.app.FragmentManager
import
androidx.fragment.app.FragmentManager
import
androidx.fragment.app.FragmentTransaction
import
androidx.fragment.app.FragmentTransaction
import
com.androidkun.xtablayout.XTabLayout
import
com.androidkun.xtablayout.XTabLayout
import
com.chineseall.reader17ksdk.feature.main.bookshop.wellchosen.WellChosenFragment
import
com.mints.goodmoney.R
import
com.mints.goodmoney.R
import
com.mints.goodmoney.common.AppConfig
import
com.mints.goodmoney.common.AppConfig
import
com.mints.goodmoney.ui.fragment.base.BaseFragment
import
com.mints.goodmoney.ui.fragment.base.BaseFragment
import
dagger.hilt.android.AndroidEntryPoint
import
kotlinx.android.synthetic.main.fragment_main_money.*
import
kotlinx.android.synthetic.main.fragment_main_money.*
/**
/**
...
@@ -27,7 +29,7 @@ class MoneyFragment : BaseFragment(), XTabLayout.OnTabSelectedListener {
...
@@ -27,7 +29,7 @@ class MoneyFragment : BaseFragment(), XTabLayout.OnTabSelectedListener {
private
var
currentFragment
:
Fragment
?
=
null
private
var
currentFragment
:
Fragment
?
=
null
private
var
mainFragment
:
Fragment
?
=
null
private
var
mainFragment
:
Fragment
?
=
null
//
private var bookStoreFragment: Fragment? = null
private
var
bookStoreFragment
:
Fragment
?
=
null
// private var newsFragment: Fragment? = null
// private var newsFragment: Fragment? = null
private
var
xmlyGameFragment
:
Fragment
?
=
null
private
var
xmlyGameFragment
:
Fragment
?
=
null
...
@@ -46,7 +48,7 @@ class MoneyFragment : BaseFragment(), XTabLayout.OnTabSelectedListener {
...
@@ -46,7 +48,7 @@ class MoneyFragment : BaseFragment(), XTabLayout.OnTabSelectedListener {
if
(
AppConfig
.
showAdFlag
)
{
if
(
AppConfig
.
showAdFlag
)
{
if
(
curPosition
==
0
)
{
if
(
curPosition
==
0
)
{
mainFragment
?.
onHiddenChanged
(
hidden
)
mainFragment
?.
onHiddenChanged
(
hidden
)
}
else
if
(
curPosition
==
3
)
{
}
else
if
(
curPosition
==
4
)
{
liebaoGameFragment
?.
onHiddenChanged
(
hidden
)
liebaoGameFragment
?.
onHiddenChanged
(
hidden
)
}
}
}
}
...
@@ -73,11 +75,11 @@ class MoneyFragment : BaseFragment(), XTabLayout.OnTabSelectedListener {
...
@@ -73,11 +75,11 @@ class MoneyFragment : BaseFragment(), XTabLayout.OnTabSelectedListener {
currentFragment
=
mainFragment
currentFragment
=
mainFragment
}
}
xtFragmentMoney
.
setxTabDisplayNum
(
4
)
xtFragmentMoney
.
setxTabDisplayNum
(
5
)
val
newTab1
=
xtFragmentMoney
.
newTab
()
val
newTab1
=
xtFragmentMoney
.
newTab
()
newTab1
.
text
=
"视频"
newTab1
.
text
=
"视频"
//
val newTab3 = xtFragmentMoney.newTab()
val
newTab3
=
xtFragmentMoney
.
newTab
()
// newTab3.text = "新闻
"
newTab3
.
text
=
"书城
"
val
newTab4
=
xtFragmentMoney
.
newTab
()
val
newTab4
=
xtFragmentMoney
.
newTab
()
newTab4
.
text
=
"听书"
newTab4
.
text
=
"听书"
val
newTab5
=
xtFragmentMoney
.
newTab
()
val
newTab5
=
xtFragmentMoney
.
newTab
()
...
@@ -85,7 +87,7 @@ class MoneyFragment : BaseFragment(), XTabLayout.OnTabSelectedListener {
...
@@ -85,7 +87,7 @@ class MoneyFragment : BaseFragment(), XTabLayout.OnTabSelectedListener {
val
newTab6
=
xtFragmentMoney
.
newTab
()
val
newTab6
=
xtFragmentMoney
.
newTab
()
newTab6
.
text
=
"来电秀"
newTab6
.
text
=
"来电秀"
xtFragmentMoney
.
addTab
(
newTab1
)
xtFragmentMoney
.
addTab
(
newTab1
)
//
xtFragmentMoney.addTab(newTab3)
xtFragmentMoney
.
addTab
(
newTab3
)
xtFragmentMoney
.
addTab
(
newTab4
)
xtFragmentMoney
.
addTab
(
newTab4
)
xtFragmentMoney
.
addTab
(
newTab5
)
xtFragmentMoney
.
addTab
(
newTab5
)
xtFragmentMoney
.
addTab
(
newTab6
)
xtFragmentMoney
.
addTab
(
newTab6
)
...
@@ -141,10 +143,15 @@ class MoneyFragment : BaseFragment(), XTabLayout.OnTabSelectedListener {
...
@@ -141,10 +143,15 @@ class MoneyFragment : BaseFragment(), XTabLayout.OnTabSelectedListener {
}
}
fun
selectBook
()
{
fun
selectBook
()
{
xtFragmentMoney
.
getTabAt
(
1
)
?.
select
()
if
(
bookStoreFragment
==
null
)
{
bookStoreFragment
=
ReaderFragment
()
}
addOrShowFragment
(
childFragmentManager
,
bookStoreFragment
!!
,
FRAGMENT_TAG_BOOKSTORE
)
}
}
fun
selectXmly
()
{
fun
selectXmly
()
{
xtFragmentMoney
.
getTabAt
(
1
)
?.
select
()
xtFragmentMoney
.
getTabAt
(
2
)
?.
select
()
if
(
xmlyGameFragment
==
null
)
{
if
(
xmlyGameFragment
==
null
)
{
xmlyGameFragment
=
XmlyFragment
()
xmlyGameFragment
=
XmlyFragment
()
}
}
...
@@ -174,18 +181,24 @@ class MoneyFragment : BaseFragment(), XTabLayout.OnTabSelectedListener {
...
@@ -174,18 +181,24 @@ class MoneyFragment : BaseFragment(), XTabLayout.OnTabSelectedListener {
}
}
1
->
{
1
->
{
if
(
bookStoreFragment
==
null
)
{
bookStoreFragment
=
ReaderFragment
()
}
addOrShowFragment
(
childFragmentManager
,
bookStoreFragment
!!
,
FRAGMENT_TAG_BOOKSTORE
)
}
2
->
{
if
(
xmlyGameFragment
==
null
)
{
if
(
xmlyGameFragment
==
null
)
{
xmlyGameFragment
=
XmlyFragment
()
xmlyGameFragment
=
XmlyFragment
()
}
}
addOrShowFragment
(
childFragmentManager
,
xmlyGameFragment
!!
,
FRAGMENT_TAG_XMLY
)
addOrShowFragment
(
childFragmentManager
,
xmlyGameFragment
!!
,
FRAGMENT_TAG_XMLY
)
}
}
2
->
{
3
->
{
if
(
liebaoGameFragment
==
null
)
{
if
(
liebaoGameFragment
==
null
)
{
liebaoGameFragment
=
LiebaoGameFragment
()
liebaoGameFragment
=
LiebaoGameFragment
()
}
}
addOrShowFragment
(
childFragmentManager
,
liebaoGameFragment
!!
,
FRAGMENT_TAG_GAME
)
addOrShowFragment
(
childFragmentManager
,
liebaoGameFragment
!!
,
FRAGMENT_TAG_GAME
)
}
}
3
->
{
4
->
{
if
(
kuYinyueFragment
==
null
)
{
if
(
kuYinyueFragment
==
null
)
{
kuYinyueFragment
=
KuYinYueFragment
()
kuYinyueFragment
=
KuYinYueFragment
()
}
}
...
...
GoodMoney/app/src/main/java/com/mints/goodmoney/ui/fragment/ReaderFragment.kt
0 → 100644
View file @
6752303b
package
com.mints.goodmoney.ui.fragment
import
android.view.View
import
androidx.fragment.app.FragmentTransaction
import
com.chineseall.reader17ksdk.ChineseAllReaderApplication
import
com.chineseall.reader17ksdk.callbacks.OnReadCallBack
import
com.chineseall.reader17ksdk.feature.main.bookshop.wellchosen.WellChosenFragment
import
com.mints.goodmoney.R
import
com.mints.goodmoney.common.AppConfig
import
com.mints.goodmoney.common.Constant
import
com.mints.goodmoney.mvp.presenters.BookPresenter
import
com.mints.goodmoney.mvp.views.BookView
import
com.mints.goodmoney.ui.fragment.base.LazyLoadBaseFragment
import
com.mints.goodmoney.utils.LogUtil
import
com.mints.goodmoney.utils.SpanUtils
import
kotlinx.android.synthetic.main.fragment_main_zy.*
/**
* 描述:听读
* 作者:孟崔广
* 时间:2021/04/08 10:55
*/
class
ReaderFragment
:
LazyLoadBaseFragment
(),
BookView
,
OnReadCallBack
{
private
val
wellChosenFragment
by
lazy
{
WellChosenFragment
(
"home"
)
}
private
val
bookPresenter
by
lazy
{
BookPresenter
()
}
override
fun
getContentViewLayoutID
()
=
R
.
layout
.
fragment_main_zy
override
fun
initViewsAndEvents
()
{}
override
fun
onFragmentFirstVisible
()
{
bookPresenter
.
attachView
(
this
)
val
transaction
:
FragmentTransaction
=
supportFragmentManager
.
beginTransaction
()
transaction
.
add
(
R
.
id
.
fragment
,
wellChosenFragment
,
ReaderFragment
::
class
.
java
.
simpleName
)
transaction
.
show
(
wellChosenFragment
)
transaction
.
commitAllowingStateLoss
()
//间隔30秒 回调一次 间隔任意设置
ChineseAllReaderApplication
.
setOnReadCallBack
(
this
,
30
*
1000
)
}
override
fun
onFragmentResume
()
{
super
.
onFragmentResume
()
if
(
AppConfig
.
fragmentClickFlag
==
Constant
.
FRAGMENT_CLICK_ONE
)
{
bookPresenter
.
getReadInfo
()
}
}
override
fun
onDestroy
()
{
super
.
onDestroy
()
ChineseAllReaderApplication
.
destory
()
bookPresenter
.
detachView
()
}
override
fun
readSecondsSuc
(
coin
:
Int
)
{
}
override
fun
readInfo
(
sumTime
:
Int
,
sumCoin
:
Int
,
readTime
:
Int
)
{
//阅读{10}分钟,奖励{xx}金币,已读{x}分钟
tvZhangContent
.
visibility
=
View
.
VISIBLE
if
(
readTime
>=
sumTime
)
{
tvZhangContent
.
text
=
"今日阅读任务已完成"
}
else
{
tvZhangContent
.
text
=
SpanUtils
()
.
append
(
"阅读"
).
append
(
"${sumTime / 60}"
).
setForegroundColor
(
mContext
.
resources
.
getColor
(
R
.
color
.
color_FF9837
)).
append
(
"分钟, "
)
.
append
(
"奖励"
).
append
(
"$sumCoin"
).
setForegroundColor
(
mContext
.
resources
.
getColor
(
R
.
color
.
color_cb4a39
)).
append
(
"金币, "
)
.
append
(
"已读"
).
append
(
"${readTime / 60}"
).
setForegroundColor
(
mContext
.
resources
.
getColor
(
R
.
color
.
color_FF9837
)).
append
(
"分钟"
)
.
create
()
}
}
override
fun
onReceive
(
map
:
Map
<
String
,
Any
>)
{
val
time
=
map
.
get
(
"time"
).
toString
().
toInt
()
val
seconds
=
(
time
/
1000
)
// 阅读5秒以上 保存时长
if
(
seconds
>
5
)
{
bookPresenter
.
addReadSeconds
(
seconds
)
}
LogUtil
.
d
(
"ReaderFragment"
,
"time:-->${time}"
)
}
}
\ No newline at end of file
GoodMoney/app/src/main/res/layout/item_banner.xml
→
GoodMoney/app/src/main/res/layout/item_
mints_
banner.xml
View file @
6752303b
File moved
GoodMoney/build.gradle
View file @
6752303b
buildscript
{
buildscript
{
ext
.
kotlin_version
=
'1.3.72'
ext
.
kotlin_version
=
'1.3.72'
ext
{
// 听读 App dependencies
appCompatVersion
=
'1.1.0'
assistedInjectVersion
=
'0.5.2'
constraintLayoutVersion
=
'2.0.0-beta3'
coreTestingVersion
=
'2.0.0'
coroutinesVersion
=
"1.3.0-M2"
espressoVersion
=
'3.1.1'
fragmentVersion
=
'1.1.0-alpha09'
glideVersion
=
'4.10.0'
gradleVersion
=
'4.0.1'
gsonVersion
=
'2.8.2'
hiltVersion
=
'2.28.3-alpha'
hiltViewModelVersion
=
'1.0.0-alpha02'
junitVersion
=
'4.12'
kotlinVersion
=
'1.4.10'
ktlintVersion
=
'0.38.1'
ktxVersion
=
'1.0.2'
lifecycleVersion
=
'2.2.0'
materialVersion
=
'1.2.0'
navigationVersion
=
'2.3.1'
okhttpLoggingVersion
=
'4.7.2'
pagingVersion
=
'3.0.0-alpha09'
recyclerViewVersion
=
'1.2.0-alpha04'
retrofitVersion
=
'2.9.0'
roomVersion
=
'2.3.0-alpha01'
runnerVersion
=
'1.0.1'
truthVersion
=
'0.42'
testExtJunit
=
'1.1.0'
uiAutomatorVersion
=
'2.2.0'
viewPagerVersion
=
'1.0.0'
workVersion
=
'2.1.0'
kotlin_version
=
'1.4.10'
arouter_compiler_version
=
'1.5.1'
arouter_api_version
=
'1.5.1'
refresh_version
=
"2.0.1"
}
repositories
{
repositories
{
google
()
google
()
jcenter
()
jcenter
()
...
@@ -18,6 +56,12 @@ buildscript {
...
@@ -18,6 +56,12 @@ buildscript {
dependencies
{
dependencies
{
classpath
'com.android.tools.build:gradle:4.0.1'
classpath
'com.android.tools.build:gradle:4.0.1'
classpath
"org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
classpath
"org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
// 听读
classpath
"androidx.navigation:navigation-safe-args-gradle-plugin:2.3.1"
classpath
"com.google.dagger:hilt-android-gradle-plugin:2.28.3-alpha"
classpath
'com.hujiang.aspectjx:gradle-android-plugin-aspectjx:2.0.10'
classpath
'com.sensorsdata.analytics.android:android-gradle-plugin2:3.3.1'
}
}
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment