和navigation有关的pendingintent的创建
pengdingintent大家都知道一般是用在广播 remoteview,或者通知的点击事件的
val pendingIntent = NavDeepLinkBuilder(context)
.setGraph(R.navigation.mobile_navigation) //这个就是navigation目录下的xml文件的名字,也就是你要跳转的activity使用的
.setDestination(R.id.fragmentStepOne) //这个就是下图你打算显示哪个fragment,那个fragment的id
.setArguments(args)
.setComponentName(ActivityNavigationTest::class.java) //这个是你要跳转的那个activity的名字
.createPendingIntent()
navigation就是2018谷歌大会退出的那个组件,咋用百度下很多的。
这里简单说下
res下新建目录navigation里边写个mobile_navigation.xml文件,如下图所示
之后activity的布局文件里这样用
<fragment
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
android:id="@+id/my_nav_host_fragment"
android:name="androidx.navigation.fragment.NavHostFragment"
app:navGraph="@navigation/mobile_navigation"
app:defaultNavHost="true"
/>
下边顺道把小部件的使用整理一下
文末有别人写的,感觉写的比较全了,想学的可以直接跳到最后
1~ 先弄个布局,就是小部件长啥样 deep_link_appwidget.xml
简单测试,就弄个文本,弄个按钮
<LinearLayout android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
xmlns:android="http://schemas.android.com/apk/res/android" >
<TextView
android:id="@+id/tv_current"
android:text="nothing"
android:layout_gravity="center"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<Button xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/deep_link"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="deeplink" />
</LinearLayout>
2~ res的xml目录下,新建个deep_link_appwidget_info.xml文件
<?xml version="1.0" encoding="utf-8"?>
<!--
updatePeriodMillis =0表示没有更新周期
android:initialLayout:就是初始化的布局,上边那个布局
android:previewImage 预览图,
android:resizeMode="horizontal|vertical" 就是小部件可以哪个方向拉伸,默认是none不可以拉伸的
-->
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
android:minWidth="110dp"
android:minHeight="40dp"
android:previewImage="@mipmap/pic11"
android:updatePeriodMillis="0"
android:resizeMode="horizontal|vertical"
android:initialLayout="@layout/deep_link_appwidget"/>
这样拉伸的
3~ 写个appwidgetProvider,就是个广播,监听小部件的状态
系统有一个默认实现的,我们只需要继承以后做点自己想要的就行
import android.appwidget.AppWidgetManager
import android.appwidget.AppWidgetProvider
import android.content.Context
import android.content.Intent
import android.os.Bundle
import android.widget.RemoteViews
import androidx.navigation.NavDeepLinkBuilder
import com.charliesong.demo0327.R
import java.text.SimpleDateFormat
import java.util.*
class DeepLinkAppWidgetProvider : AppWidgetProvider() {
override fun onUpdate(
context: Context,
appWidgetManager: AppWidgetManager,
appWidgetIds: IntArray
) {
val remoteViews = RemoteViews(
context.packageName,
R.layout.deep_link_appwidget
)
println("appWidgetIds==============${Arrays.toString(appWidgetIds)}")
val args = Bundle()
args.putString("myarg", "From Widget")
// TODO Step 11 - construct and set a PendingIntent using DeepLinkBuilder
val pendingIntent = NavDeepLinkBuilder(context)
.setGraph(R.navigation.mobile_navigation)
.setDestination(R.id.fragmentStepOne)
.setArguments(args)
.setComponentName(ActivityNavigationTest::class.java)
.createPendingIntent()
remoteViews.setOnClickPendingIntent(R.id.deep_link, pendingIntent)
// TODO ENDSTEP 11
remoteViews.setTextViewText(R.id.tv_current,format.format(Date(System.currentTimeMillis())))
appWidgetManager.updateAppWidget(appWidgetIds, remoteViews)
}
val format=SimpleDateFormat("yy-MM-dd HH:mm:ss", Locale.CHINA)
override fun onAppWidgetOptionsChanged(context: Context?, appWidgetManager: AppWidgetManager?, appWidgetId: Int, newOptions: Bundle?) {
super.onAppWidgetOptionsChanged(context, appWidgetManager, appWidgetId, newOptions)
println("onAppWidgetOptionsChanged=================$newOptions")
}
override fun onDeleted(context: Context?, appWidgetIds: IntArray?) {
super.onDeleted(context, appWidgetIds)
println("onDeleted===============")
}
override fun onDisabled(context: Context?) {
super.onDisabled(context)
println("onDisabled================")
}
override fun onEnabled(context: Context?) {
super.onEnabled(context)
println("onEnabled=================")
}
override fun onRestored(context: Context?, oldWidgetIds: IntArray?, newWidgetIds: IntArray?) {
super.onRestored(context, oldWidgetIds, newWidgetIds)
println("onRestored=======================")
}
override fun onReceive(context: Context?, intent: Intent?) {
println("onReceive======================${intent?.action}")
super.onReceive(context, intent)
}
}
简单测试下,首次把小部件拉到桌面,会收到
ACTION_APPWIDGET_ENABLED
ACTION_APPWIDGET_UPDATE
然后把小部件移除的时候会收到
APPWIDGET_DELETED
APPWIDGET_DISABLED
上边都有对应的方法,然后处理自己的需求即可。
至于appWidgetIds 那个数组,第一次可能是个数字6,然后你移除再添加就成7了,继续就成8了,应该是递增的,至于第一次是几,那咋算的,不太清楚。
4~既然是广播,自然需要注册的
<receiver android:name=".navigation.DeepLinkAppWidgetProvider">
<intent-filter>
<action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
</intent-filter>
<meta-data
android:name="android.appwidget.provider"
android:resource="@xml/deep_link_appwidget_info" />
</receiver>
小部件一般咋添加到桌面
长按屏幕应该就可以看到,或者有的是两根手指往屏幕中间滑。
现在新的系统的话,长按app的launcher图标也可以看到的
结果
我6.0的平板,没啥问题,可以正常显示。
可8.0的模拟器,也没任何异常信息,就是小部件显示错误,如下图
然后去搜下,感觉介绍的比较详细了。
https://www.cnblogs.com/skywang12345/p/3158310.html