xposed方面的备忘录

xposed方面的备忘录,第1张

Xposed 摘要

验证Xposed模块自身是否被启用

Java反射机制、动态代理(过滤器Filter和拦截器Interceptor)

xposedAPI文档: >

new Intent()构造函数接受两个参数,

第一个参数为Context上下文,可以为application(全局上下文)、自定义Context、或者当前Activity,一般多为当前activity

比如,从A页面活动跳转到B页面活动,代码如下(在A页面代码写入):

Intent intent=new Intent(Athis,BClass);

startActivity(intent);

目标activity一般可以为activity、service等

Intent(意图)主要是解决Android应用的各项组件之间的通讯。

为了实现传递数据这个目的需要以下步骤

Activity1需要构造一个 Intent,这个Intent用于告诉系统,我们要做“查看”动作

intent可调用putExtra来存放想要传递的数据

然后调用setClass,设置Activity1和欲调用的组件Activity2

最后调用startActivity将构造的Intent传入,系统会根据此Intent中的描述,到Activity1中找到满足此Intent要求的Activity,系统会调用找到的 Activity2最终传入Intent

在Activity2中可使用getIntent来获取传递的Intent,并通过获取数据的方法来获取数据

代码示例:

Intent intent = new Intent();  // Activity1

            intentputExtra("one", num1);  

            intentputExtra("two", num2);  

            intentsetClass(FirstActivitythis, SecondActivityclass);  

                startActivity(intent); Intent intent = getIntent();  //Activity2

        String num1 = intentgetStringExtra("one");  

        String num2 = intentgetStringExtra("two");  

        int ret = IntegerparseInt(num1) + IntegerparseInt(num2);  

        resultsetText(ret+"");

注意:我们在使用intent的时候可以使用bundle传递复制的数据类型。

SiriKit是您通过Siri提供内容的一种方式。 它还允许您向 Maps 应用添加对服务的支持。 要支持 SiriKit ,您可以使用 Intents 框架和 Intents UI 框架来实现一个或多个扩展,然后将这些扩展包含在iOS应用程序中。 当用户通过Siri或Maps请求特定类型的服务时,系统会使用您的扩展来提供这些服务。

仅当您的应用程序实现以下类型的服务之一时才添加SiriKit支持:

汽车制造商可以使用 CarPlay intents 允许用户使用语音命令控制汽车功能。

每种类型的服务代表您可以支持的功能域,每个域定义一个或多个意图供您支持。 意图是表示用户意图的对象。 Siri和Maps创建意图对象以响应用户请求,并使用任何用户指定的信息填充它们。 例如,发送消息的意图可能包括消息的接收者和内容。 您使用intent对象提供适当的响应并执行相关的任务。 有关支持的域及其意图的更多信息,请参阅 Intents Domains 。

Siri 和 Maps 通过两种不同类型的扩展与您的应用服务进行互动:

您必须提供 Intents 扩展才能支持 SiriKit 。您的Intents扩展程序负责处理意图并提供Siri和Maps可用于与用户通信的信息。提供 Intents UI 扩展是可选的,但是通过Siri与您的应用进行交互的方式对您的用户来说似乎很熟悉。例如,Intents UI扩展可以显示横幅和其他特定于应用的信息,以强化您的应用正在提供响应。

有关用于实现Intents扩展的类的信息,请参阅 Intents Framework Reference 。有关用于实现 Intents UI 扩展的协议的信息,请参阅 Intents UI Framework Reference 。

Siri处理将用户的语音请求转换为扩展可以处理的可 *** 作意图所需的语言处理和语义分析。 Siri和Maps应用程序管理所有用户交互,并使用标准系统界面向用户显示结果。 您的角色主要是提供要显示的数据。 如果您的应用程序包含Intents UI扩展,您还可以提供自定义界面来补充默认系统界面。

乘车预订和餐厅预订主要由 Maps 应用程序处理,尽管用户也可以使用Siri预订游乐设施。 您的Intents扩展程序处理源自Maps应用程序的交互,其处理方式与处理来自Siri的请求的方式相同。 如果您自定义用户界面,您的 Intents UI 扩展可以根据请求来自Siri还是Maps来进行不同的配置。

Siri 和 Maps 通过您的 Intents 扩展程序与您的应用互动。 Intents扩展的入口点是 INExtension 对象,其唯一的工作是将Siri指向能够响应用户请求的对象。实现 Intents 扩展时,您经常使用三种类型的对象:

当您的扩展程序有意图处理时,Siri会询问您的 INExtension 对象是否有能够处理该意图的对象。处理程序对象可以是您想要的任何类型,但它必须实现处理给定意图所需的特定方法。每个 intent 都有一个与其处理程序必须采用的关联协议。该协议的方法分为三组:解决方法,确认方法和处理方法。您可以实现所需的方法,并向Siri提供有关您计划如何处理意图的信息。

图2-1说明了Siri与扩展中的处理程序对象之间的高级别流程。在该示例中,当用户要求使用乘车预订服务预订乘车时,Siri创建具有乘坐参数的意图对象并将其发送给处理者。处理程序将intent对象中的数据解析为可用于完成行程的值。当所有骑行参数都已解决后,Siri要求处理者确认其计划如何处理乘坐请求并执行任何最终验证。在确认阶段,处理程序提供一个响应对象,其中包含骑行的详细信息,Siri可能会向用户显示。如果用户接受了乘坐,Siri要求乘车请求处理者处理该意图。处理程序通过预订车辆并回复预订车辆的详细信息来回应。

有关如何创建扩展的一般信息,请参阅 App Extension Programming Guide 。

要支持 SiriKit ,请在您的iOS应用中添加 Intents extension 。

Xcode提供的 Intents 扩展模板包含一个 INExtension 子类供您自定义。 您可以使用该类来创建处理意图所需的处理程序对象。 Siri使用您的扩展的 Infoplist 文件来发现它支持的意图。 Xcode提供的 Infoplist 文件主要是配置的,但您必须修改它的一部分以指定扩展程序处理的意图。

这个key是必需的。您可以支持给定域中的所有或部分意图,并且您的扩展可以支持任意数量的域。该值必须包含扩展支持的所有 intent 类。

此键是可选的。该值包含您需要解锁设备的 intent 类的子集。如果处理意图涉及访问磁盘上的受保护文件或 *** 纵敏感用户数据,则可能在此列表中包含 intent 。

实现扩展的行为涉及以下任务:

有关可用意图的列表以及为每个意图实现的关联类和协议,请参阅 Intents Domains 。

在使用Intents扩展程序之前,在注册任何特定于用户的词汇表之前,您的iOS应用程序必须请求授权才能使用Siri。 要请求授权,请执行以下 *** 作:

您的iOS应用首次调用 requestSiriAuthorization: 方法时,系统会显示一条alertd窗,提示用户授权您的应用。d窗包括您在应用的 Infoplist 文件的 NSSiriUsageDescription 键中提供的使用说明字符串。用户可以批准或拒绝您的应用程序的授权请求,并可以稍后在“设置”应用中更改您应用的授权状态。系统会记住您的应用程序的授权状态,以便后续调用 requestSiriAuthorization: 方法不会再次提示用户。

您的 Intents 扩展程序是代表您的应用程序执行的代理程序,应该能够执行与您的应用程序相同的服务。由于您的iOS应用和 Intents 扩展执行许多相同的任务,请考虑以下事项:

要测试 Intents 扩展,必须在设备上运行它。 Xcode支持直接从Xcode项目启动Intents扩展,并在设备上运行时对其进行调试。

当您向项目添加Intents扩展时,Xcode会自动创建一个运行该扩展的 scheme 。

您无法在模拟器中调试 Intents 扩展。

Xcode构建您的应用和扩展,将它们安装在设备上,然后启动Siri。

首次安装您的扩展程序时,Siri可能无法立即识别您的应用扩展程序。您可能需要等待几分钟才能发出任何相关命令。同样,在更新Infoplist文件时,您可能需要等待几分钟,然后Siri才能识别出更改。

您的iOS应用程序使用 Intents 框架执行特定任务:

用户可以为Siri配置与设备其余部分不同的语言。 在iOS应用程序中,系统使用特定于设备的语言设置检索本地化内容。 在 Intents 扩展中,系统使用Siri语言检索本地化内容。 如果您的应用与扩展程序共享本地化内容,则必须使用 Siri 语言共享该内容,您的应用可以使用 INPreferences 类的 siriLanguageCode 方法检索该语言。

有关获取Siri语言的更多信息,请参阅 INPreferences Class Reference 。

在 Intents 扩展中,处理程序对象执行解析,确认和处理Siri发送的intent对象的关键工作。每个intent对象都有一个专门为处理该intent而设计的相关协议。例如, INRequestRideIntent 对象的处理程序采用 INRequestRideIntentHandling 协议。

每种协议的方法分为三组:

实现处理程序时,必须始终实现处理intent的方法。所有其他方法都是可选的,但建议使用。解决和确认方法是您在尝试处理意图之前验证意图内容的机会。您还可以使用这些方法来标识或创建处理意图所需的内部数据对象。

有关意图列表和相应的意图处理协议,请参阅 Intents Domains 。

在意图的解决阶段,Siri要求您的处理程序解析关键参数并确认您打算使用的值。因为说出了来自用户的数据,所以可能存在丢失或模糊的信息。解决阶段是您验证所提供数据的机会,并让Siri知道您是否需要澄清或更多信息。建议您为给定的处理程序协议实现所有解析方法。虽然您可能不会使用所有参数,但每种方法都会告诉Siri您是否在自己的数据结构中找到了适当的值。

您使用解析结果对象将解析结果传回 SiriKit ,解析结果对象是 INIntentResolutionResult 类的实例。您可能需要解析每种参数类型的不同子类。例如,在以 INPerson 对象的形式解析联系人时,将返回 INPersonResolutionResult 类的实例。实例化子类时,请使用与解析工作结果相对应的创建方法。表3-1列出了可能的结果,并说明了何时使用每种结果。

Table 3-1 Possible outcomes when resolving intent parameters

解析参数时,尝试尽快达成成功的解决方案。 询问更多信息会导致额外的用户交互以及对处理程序的额外调用,从而导致延迟并可能使用户感到沮丧。 相反,尝试根据用户的模式和习惯选择合理的值,并仅在需要时要求消除歧义或确认。

Listing 3-1 显示了乘坐预订应用程序的示例,该应用程序验证了乘车的下车位置。 如果存在一个下车位置,则该方法返回一个成功的结果;否则,该方法返回表示需要该值的结果。

Activity之间是如何调用的

在javaWeb程序中,jsp与jsp之间的调用是通过重定向完成的,而在Android中,Activity与Activity之间的切换是通过Intent来完成的。

谓Intent,它是Android中非常重要的内置组件,他可以理解为“我要干一件什么事情”。在Android中有3大组

件:Activity,Service、Broadcast,他们之间的通信都是通过Intent来完成的,所以Intent其实就是告诉他们之间的每一

个人,要干什么事情。

创建自己的Activity

高焕堂先生的Android讲义中有如下一段内容:

Android的4种嫡系组件(即Activity、Service、IntentReceiver和ContentProvider)之间如何互相沟通呢?这4种嫡系组件都是由Android启动的,并不是组件之间透过直接呼叫而启动的。

段文字总结的十分精辟,它告诉了读者(以Activity为例)Activity是Android自启动的,这样的话,编程人员必须要明确告诉

Android“我的应用程序里面有哪些是你要给我启动的”,而如何告诉Android这些信息呢,Android为我们提供了一个

AndroidManifestxml文件。在这个文件中,就可以告诉Android这些内容。这也是为什么我们在建立了自己的Activity、

ContentProvider等之后,必须要在配置文件中进行配置的原因。

以下代码是在自己定义的一个名为SecondActivity的Activity,其配置代码如下:

<activity android:name="SecondActivity"

android:label="secondActivity">

</activity>

在android:name一项中中的“”代表在当前配置文件的默认包名之下。

Activity之间的切换

从一个Activity调用另一个Activity,十分简单,只需要创建一个Intent,并且告诉Intent我从哪来,要到哪去,然后执行这个Intent,就可以了。示例代码如下:

Intent i = new Intent(TestActivitythis,SecondActivityclass);

startActivity(i);

然,这样只能够做到Activity之间的切换,如果想在切换的同时,由旧的Activity向新的Activity传递一些参数,那么就要在

startActivity()方法之前,为Intent添加参数,通过putExtra(string,xxx)这组方法,就可实现。

putExtra(string,xxx)方法类似于map,键都是String型,值有不公类型,该方法被重载,具体可参考API,示例代码如下:

Intent i = new Intent(TestActivitythis,SecondActivityclass);

iputExtra("uName", "legend");

iputExtra("uAge", (short)18);

startActivity (i);

获取Intent传递的值

旧的Activity将值传递给了新的Activity,那么在新的Activity中,要通过getIntent()方法,方可接收传递过来的Intent。得到Intent后通过getxxxExtra()方法,可以取得不同类型的值。如下所示:

Intent i = getIntent();

String uName = igetStringExtra("uName");

short uAge = igetShortExtra("uAge", (short) 0);

旧Activity得到新Activity结束后传递的Intent

开发中,有这种情况,比如说我们的一个Activity要调用一个新的Activity,让后用户对新的Activity *** 作完成后,关闭新的

Activity,这时需要将新的Activity中的一些值传递给旧的Activity。这就中情况不用自己处理,Android已经为我们编写了一个

onActivityResult(int requestCode, int resultCode, Intent

data)方法,专门处理这种情况。

首先,在旧的Acitvity中的启动Intent方法不能再使用之前的

startActivity,而要给用startActivityForResult(i, REQUESTCODE1

);方法,该方法第一个参数为要传递的intent,第二个参数为请求码,该请求码其实就是一个整型变量,用于指明是那个方法、或者说是那个控件启动了该

intent,其最主要的目的是在onActivityResult(int requestCode, int resultCode, Intent

data)方法中,编程使用。读者这里可以不用深究,看到例子后,便会明白。该处代码如下:

Intent i = new Intent(TestActivitythis,SecondActivityclass);

iputExtra("uName", "legend");

iputExtra("uAge", (short)18);

startActivityForResult(i, REQUESTCODE1 );

次,在新的Activity中要接受刚刚传递的Intent,接受方法如上所述,这里不再赘述。在新的Acitvity处理完成后,需要同过

setResult(Intent

i)方法来设置新的Activity结束后需要传递会旧的Activity的Intent。之后调用新的Activity的finish()方法,结束新

的Acitvity就可以了。代码如下:

Intent resultIntent = new Intent();

resultIntentputExtra("uName", "legend2");

resultIntentputExtra("uAge", (short)22);

setResult(RESULTCODE1, resultIntent);

SecondActivitythisfinish();

最后,在旧的Activity中重写onActivityResult(int requestCode, int resultCode, Intent data)方法,该方法的三个参数,这里就不在赘述了,相信读者一看即明白,这里给出代码如下:

if(requestCode == REQUESTCODE1){

Systemoutprintln("REQUESTCODE equal");

if(resultCode == SecondActivityRESULTCODE1){

Systemoutprintln("RESULTCODE equal");

String uName = datagetStringExtra("uName");

short uAge = datagetShortExtra("uAge", (short)0);

tvsetText("uName:"+uName+" uAge:"+uAge);

}

}

参考程序

ActivityTest

补充:

Intent中,可以携带Object类型的信息,读者查阅API后,可能会放先,putExtra()方法中,并没有实现object的,但是重载了如

下的方法:putExtra(String name, Serializable

value),只要将对象实现了Serializable接口,就可以添加进Intent了。

对象序列化及反序列化

一个对象产生后,实际上是在内存中开辟了一个存储空间,方便存储信息。

对象的序列化,就是一个对象变成二进制数据流的一种方法,通过对象的序列化可以方便的实现对象的传输与存储。

如果一个类的对象想要被序列化,必须实现Serializable接口,但是该接口中无方法,它属于一个标示接口,表示具备了某种能力。

序列化和反序列化,可以理解为:

序列化:程序àObjectOutputStreamà序列化对象

反序列化:序列化对象àObjectInputStreamà程序

在序列化的时候,可以通过serialVersionUID来标识序列化版本。

值得注意的是,序列化存储的只是对象的成员变量。

ObjectInputStream中的readObject()方法可读取对象。

ObjectOutputStream中的writeObject()方法可写入对象。

getExtras()返回的是Bundle的对象,我来给楼主写个小例子,你一看就懂了:

现在我们要从MainActivity跳转到SecondActivity,并且携带一个参数过去,那么MainActivity里跳转界面的代码这样写:

Intent intent=new Intent(this,SecondActivityclass);

Bundle bundle=new Bundle();

bundleputString("test", "楼主采纳我吧");

intentputExtras(bundle);

startActivity(intent);

可以看到new出了一个bundle,在bundle里面放置了一个key为"test",值为"楼主采纳我吧"的键值对,然后把bundle放到intent里,intent携带了一个bundle对象,就开始跳转界面了,那么在SecondActivity里接收参数,就应该这么写:

String params=thisgetIntent()getExtras()getString("test");

这时候params的值就是“楼主采纳我吧”。

以上就是关于xposed方面的备忘录全部的内容,包括:xposed方面的备忘录、我在传入的activity如何得的intent是从哪个activity传来的、安卓studio intent怎么用new intent()括号里的两个参数怎么填等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9747902.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存