keep screen on
This commit is contained in:
parent
d8fffbb402
commit
434915fd3d
|
|
@ -3,4 +3,4 @@
|
|||
/cmake_install.cmake
|
||||
/CMakeFiles/
|
||||
/Makefile
|
||||
/src/main/cpp/native-lib.c
|
||||
/src/main/cpp/native.c
|
||||
|
|
|
|||
|
|
@ -15,17 +15,17 @@ if (IS_SO_BUILD)
|
|||
# and CMake builds them for you. When you build your app, Gradle
|
||||
# automatically packages shared libraries with your APK.
|
||||
add_library( # Specifies the name of the library.
|
||||
native-lib
|
||||
native
|
||||
|
||||
# Sets the library as a shared library.
|
||||
SHARED
|
||||
|
||||
# Provides a relative path to your source file(s).
|
||||
src/main/cpp/native-lib.c)
|
||||
src/main/cpp/native.c)
|
||||
|
||||
# 设置编译输出路径
|
||||
set_target_properties(
|
||||
native-lib
|
||||
native
|
||||
PROPERTIES
|
||||
LIBRARY_OUTPUT_DIRECTORY
|
||||
${CMAKE_SOURCE_DIR}/src/main/cpp/${ANDROID_ABI}
|
||||
|
|
@ -36,18 +36,18 @@ else ()
|
|||
SHARED
|
||||
src/main/cpp/nothing.c)
|
||||
|
||||
add_library(native-lib
|
||||
add_library(native
|
||||
SHARED
|
||||
IMPORTED)
|
||||
|
||||
set_target_properties( # Specifies the target library.
|
||||
native-lib
|
||||
native
|
||||
|
||||
# Specifies the parameter you want to define.
|
||||
PROPERTIES IMPORTED_LOCATION
|
||||
|
||||
# Provides the path to the library you want to import.
|
||||
${CMAKE_SOURCE_DIR}/src/main/cpp/${ANDROID_ABI}/libnative-lib.so)
|
||||
${CMAKE_SOURCE_DIR}/src/main/cpp/${ANDROID_ABI}/libnative.so)
|
||||
endif ()
|
||||
|
||||
add_library(libssl
|
||||
|
|
@ -87,7 +87,7 @@ find_library( # Defines the name of the path variable that stores the
|
|||
if (IS_SO_BUILD)
|
||||
# Links your native library against one or more other native libraries.
|
||||
target_link_libraries( # Specifies the target library.
|
||||
native-lib
|
||||
native
|
||||
libssl
|
||||
libcrypto
|
||||
${log-lib})
|
||||
|
|
@ -96,6 +96,6 @@ else ()
|
|||
nothing
|
||||
libssl
|
||||
libcrypto
|
||||
native-lib
|
||||
native
|
||||
${log-lib})
|
||||
endif ()
|
||||
|
|
@ -104,7 +104,7 @@ dependencies {
|
|||
implementation 'com.squareup.retrofit2:retrofit:2.9.0'
|
||||
implementation "org.jetbrains.kotlinx:kotlinx-serialization-json:1.6.2"
|
||||
implementation 'androidx.core:core-ktx:1.11.0-beta02'
|
||||
implementation 'androidx.leanback:leanback:1.0.0'
|
||||
implementation 'androidx.leanback:leanback:1.2.0-alpha02'
|
||||
implementation 'com.github.bumptech.glide:glide:4.11.0'
|
||||
implementation "androidx.lifecycle:lifecycle-runtime-ktx:2.6.2"
|
||||
implementation("org.jetbrains.kotlinx:kotlinx-coroutines-android:1.8.0-RC")
|
||||
|
|
|
|||
|
|
@ -14,6 +14,7 @@
|
|||
android:supportsRtl="true"
|
||||
android:theme="@style/Theme.MyTV">
|
||||
<activity
|
||||
android:keepScreenOn="true"
|
||||
android:name=".MainActivity"
|
||||
android:banner="@drawable/tv"
|
||||
android:exported="true"
|
||||
|
|
|
|||
Binary file not shown.
Binary file not shown.
Binary file not shown.
|
|
@ -11,7 +11,7 @@ class Encryptor {
|
|||
|
||||
companion object {
|
||||
init {
|
||||
System.loadLibrary("native-lib")
|
||||
System.loadLibrary("native")
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -11,6 +11,7 @@ import android.os.Handler
|
|||
import android.os.Looper
|
||||
import android.util.Log
|
||||
import android.view.KeyEvent
|
||||
import android.view.WindowManager
|
||||
import android.widget.ImageView
|
||||
import android.widget.LinearLayout
|
||||
import android.widget.TextView
|
||||
|
|
@ -32,6 +33,8 @@ class MainActivity : FragmentActivity() {
|
|||
super.onCreate(savedInstanceState)
|
||||
setContentView(R.layout.activity_main)
|
||||
|
||||
window.addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
|
||||
|
||||
if (savedInstanceState == null) {
|
||||
supportFragmentManager.beginTransaction()
|
||||
.add(R.id.main_browse_fragment, playbackFragment)
|
||||
|
|
|
|||
|
|
@ -36,6 +36,16 @@ class MainFragment : BrowseSupportFragment() {
|
|||
|
||||
private var sharedPref: SharedPreferences? = null
|
||||
|
||||
// override fun onCreateView(
|
||||
// inflater: LayoutInflater,
|
||||
// container: ViewGroup?,
|
||||
// savedInstanceState: Bundle?
|
||||
// ): View? {
|
||||
// super.onCreate()
|
||||
// // 使用自定义的布局文件
|
||||
// return inflater.inflate(R.layout.custom_browse_fragment, container, false)
|
||||
// }
|
||||
|
||||
override fun onActivityCreated(savedInstanceState: Bundle?) {
|
||||
super.onActivityCreated(savedInstanceState)
|
||||
|
||||
|
|
@ -66,7 +76,6 @@ class MainFragment : BrowseSupportFragment() {
|
|||
|
||||
private fun setupUIElements() {
|
||||
brandColor = ContextCompat.getColor(context!!, R.color.fastlane_background)
|
||||
// headersState = HEADERS_DISABLED
|
||||
}
|
||||
|
||||
private fun updateRows(tv: TV) {
|
||||
|
|
@ -111,17 +120,29 @@ class MainFragment : BrowseSupportFragment() {
|
|||
adapter = rowsAdapter
|
||||
|
||||
itemPosition = sharedPref?.getInt("position", 0)!!
|
||||
if (itemPosition >= tvListViewModel.size()) {
|
||||
itemPosition = 0
|
||||
savePosition(0)
|
||||
}
|
||||
|
||||
val tv = list2[itemPosition].item
|
||||
|
||||
val tvModel = tvListViewModel.getTVModel(itemPosition)
|
||||
if (tvModel?.ysp() != null) {
|
||||
Log.i(TAG, "ysp ${tvModel.getTV()}")
|
||||
lifecycleScope.launch(Dispatchers.IO) {
|
||||
tvModel.let { request?.fetchData(it) }
|
||||
}
|
||||
} else {
|
||||
(activity as? MainActivity)?.play(list2[itemPosition].item)
|
||||
// (activity as? MainActivity)?.switchInfoFragment(list2[itemPosition].item)
|
||||
(activity as? MainActivity)?.play(tv)
|
||||
// (activity as? MainActivity)?.switchInfoFragment(tv)
|
||||
}
|
||||
|
||||
Toast.makeText(
|
||||
activity,
|
||||
tv.title,
|
||||
Toast.LENGTH_SHORT
|
||||
).show()
|
||||
(activity as? MainActivity)?.switchMainFragment()
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -89,6 +89,7 @@ class Request(var context: Context) {
|
|||
override fun onResponse(call: Call<LiveInfo>, response: Response<LiveInfo>) {
|
||||
if (response.isSuccessful) {
|
||||
val liveInfo = response.body()
|
||||
Log.i(TAG, "liveInfo $liveInfo")
|
||||
if (liveInfo?.data?.playurl != null) {
|
||||
val chanll = liveInfo.data.chanll
|
||||
val decodedBytes = Base64.decode(
|
||||
|
|
@ -117,6 +118,7 @@ class Request(var context: Context) {
|
|||
}
|
||||
|
||||
override fun onFailure(call: Call<LiveInfo>, t: Throwable) {
|
||||
Log.i(TAG, "get data error")
|
||||
}
|
||||
})
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,6 +1,5 @@
|
|||
package com.lizongying.mytv.models
|
||||
|
||||
import android.util.Log
|
||||
import androidx.lifecycle.MutableLiveData
|
||||
import androidx.lifecycle.ViewModel
|
||||
import com.lizongying.mytv.TV
|
||||
|
|
@ -41,4 +40,8 @@ class TVListViewModel : ViewModel() {
|
|||
fun getTVModel(id: Int): TVViewModel? {
|
||||
return tvModelListLiveData.value?.get(id)
|
||||
}
|
||||
|
||||
fun size(): Int {
|
||||
return tvListLiveData.value!!.size
|
||||
}
|
||||
}
|
||||
Loading…
Reference in New Issue