public class MainActivity extends AppCompatActivity { private EditText numberEditText; private Button sendButton; private BroadcastReceiver broadcastReceiver = new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { int result = intent.getIntExtra("factorial", 0); textView.setText("Factorial: " + result); } }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); numberEditText = findViewById(R.id.numberEditText); sendButton = findViewById(R.id.sendButton); sendButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { int number = Integer.parseInt(numberEditText.getText().toString()); Intent intent = new Intent("com.example.FACTORIAL_ACTION"); intent.putExtra("number", number); sendBroadcast(intent); } }); } @Override protected void onResume() { super.onResume(); IntentFilter filter = new IntentFilter("com.example.FACTORIAL_ACTION"); registerReceiver(broadcastReceiver, filter); } @Override protected void onPause() { super.onPause(); unregisterReceiver(broadcastReceiver); } }

时间: 2024-02-14 20:31:33 浏览: 16
这段代码是一个示例的 MainActivity 类,它包含了一个 EditText、一个 Button 和一个 BroadcastReceiver。 在这段代码中,我们首先定义了一个 BroadcastReceiver,它的作用是接收广播并执行相应的操作。 在 onCreate() 方法中,我们通过 findViewById() 方法获取了 numberEditText 和 sendButton 的引用,并为 sendButton 设置了一个点击事件监听器。当用户点击按钮时,会从 numberEditText 中获取输入的数字,并创建一个带有自定义 action 的 Intent,并将数字作为额外的数据放入 Intent 的 extras 中。然后,通过 sendBroadcast() 方法发送广播。 在 onResume() 方法中,我们创建了一个 IntentFilter,并将自定义 action 添加到过滤器中。然后,调用 registerReceiver() 方法注册广播接收器,并将过滤器作为参数传递。这样,当有匹配的广播发送时,广播接收器的 onReceive() 方法就会被调用。 在 onPause() 方法中,我们调用 unregisterReceiver() 方法取消注册广播接收器,以避免内存泄漏。 总结一下,这段代码演示了一个 Activity 发送广播的过程,以及如何注册和取消注册广播接收器来接收广播并执行相应的操作。
相关问题

Android应用程序开发BroadcastReceiver编程作业编写一个程序,实现简单的短信收发操作

以下是一个简单的 Android 应用程序开发 Broadcast Receiver 编程作业,实现短信收发操作的示例代码: 1. 创建一个新的 Android 项目并添加以下权限到 AndroidManifest.xml 文件中: ```xml <uses-permission android:name="android.permission.RECEIVE_SMS" /> <uses-permission android:name="android.permission.SEND_SMS" /> ``` 2. 创建一个名为 SMSReceiver 的类,它继承 BroadcastReceiver 并重写 onReceive() 方法。在该方法中,我们可以获取短信消息并在控制台上输出它们: ```java public class SMSReceiver extends BroadcastReceiver { private static final String SMS_RECEIVED = "android.provider.Telephony.SMS_RECEIVED"; @Override public void onReceive(Context context, Intent intent) { if (intent.getAction().equals(SMS_RECEIVED)) { Bundle bundle = intent.getExtras(); if (bundle != null) { Object[] pdusObj = (Object[]) bundle.get("pdus"); if (pdusObj != null) { for (Object pduObj : pdusObj) { SmsMessage currentMessage = SmsMessage.createFromPdu((byte[]) pduObj); String senderNum = currentMessage.getDisplayOriginatingAddress(); String message = currentMessage.getDisplayMessageBody(); Log.i("SMSReceiver", "Sender: " + senderNum + " Message: " + message); } } } } } } ``` 3. 在 MainActivity 中,我们可以使用以下代码来发送短信消息: ```java public class MainActivity extends AppCompatActivity { private static final int MY_PERMISSIONS_REQUEST_SEND_SMS = 0; private Button sendButton; private EditText phoneEditText; private EditText messageEditText; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); sendButton = findViewById(R.id.send_button); phoneEditText = findViewById(R.id.phone_edit_text); messageEditText = findViewById(R.id.message_edit_text); sendButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { String phone = phoneEditText.getText().toString(); String message = messageEditText.getText().toString(); if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.SEND_SMS) != PackageManager.PERMISSION_GRANTED) { ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.SEND_SMS}, MY_PERMISSIONS_REQUEST_SEND_SMS); } else { SmsManager smsManager = SmsManager.getDefault(); smsManager.sendTextMessage(phone, null, message, null, null); Toast.makeText(MainActivity.this, "Message sent!", Toast.LENGTH_SHORT).show(); } } }); } @Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { if (requestCode == MY_PERMISSIONS_REQUEST_SEND_SMS) { if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { sendButton.performClick(); } else { Toast.makeText(MainActivity.this, "SMS permission denied.", Toast.LENGTH_SHORT).show(); } } } } ``` 4. 最后,我们需要在 AndroidManifest.xml 文件中注册 SMSReceiver 类: ```xml <receiver android:name=".SMSReceiver"> <intent-filter> <action android:name="android.provider.Telephony.SMS_RECEIVED" /> </intent-filter> </receiver> ``` 这是一个简单的 Android 应用程序开发 Broadcast Receiver 编程作业,实现短信收发操作的示例代码。

1. 编程实现Intent的显示跳转。在MainActivity中定义Intent,启动SeconActivity,能够获取SecondActivity的返回值; 2、使用Intent过滤器实现隐式跳转。在MainActiviy中定义Intent,要求必须用到自定义的action、category、data来启动ThirdActivity; 3. 实现通过Intent调用android内置浏览器; 4. 通过Intent实现广播消息的接收。在MainActivity中定义Intent,将界面上某文本框中的内容以广播消息的形式发出。广播消息可以使用Toast或Logcat。

1. 显示跳转并获取返回值: 在 MainActivity 中定义 Intent,并使用 startActivityForResult() 方法启动 SecondActivity。在 SecondActivity 中设置返回结果,并使用 setResult() 方法返回结果。在 MainActivity 中重写 onActivityResult() 方法获取返回结果。 MainActivity.java: ```java public class MainActivity extends AppCompatActivity { private static final int REQUEST_CODE = 1; private TextView resultTextView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Button goToSecondButton = findViewById(R.id.go_to_second_button); resultTextView = findViewById(R.id.result_text_view); goToSecondButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(MainActivity.this, SecondActivity.class); startActivityForResult(intent, REQUEST_CODE); } }); } @Override protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) { super.onActivityResult(requestCode, resultCode, data); if (requestCode == REQUEST_CODE && resultCode == RESULT_OK && data != null) { String result = data.getStringExtra(SecondActivity.EXTRA_RESULT); resultTextView.setText(result); } } } ``` SecondActivity.java: ```java public class SecondActivity extends AppCompatActivity { public static final String EXTRA_RESULT = "com.example.myapplication.RESULT"; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_second); Button returnButton = findViewById(R.id.return_button); returnButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { String result = "Hello, MainActivity!"; Intent intent = new Intent(); intent.putExtra(EXTRA_RESULT, result); setResult(RESULT_OK, intent); finish(); } }); } } ``` 2. 使用 Intent 过滤器实现隐式跳转: 在 MainActivity 中定义 Intent,并设置自定义的 action、category、data。在 ThirdActivity 的 AndroidManifest.xml 文件中使用 intent-filter 元素来指定响应的 Intent。 MainActivity.java: ```java public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Button goToThirdButton = findViewById(R.id.go_to_third_button); goToThirdButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(); intent.setAction("com.example.myapplication.ACTION_THIRD"); intent.addCategory("com.example.myapplication.CATEGORY_THIRD"); intent.setData(Uri.parse("https://www.example.com")); startActivity(intent); } }); } } ``` ThirdActivity 的 AndroidManifest.xml: ```xml <activity android:name=".ThirdActivity"> <intent-filter> <action android:name="com.example.myapplication.ACTION_THIRD" /> <category android:name="com.example.myapplication.CATEGORY_THIRD" /> <data android:scheme="https" android:host="www.example.com" /> </intent-filter> </activity> ``` ThirdActivity.java: ```java public class ThirdActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_third); } } ``` 3. 通过 Intent 调用 Android 内置浏览器: 在 MainActivity 中定义 Intent,并使用 setData() 方法设置要打开的网址。然后使用 startActivity() 方法启动隐式 Intent,Android 系统会自动选择合适的应用程序打开该网址。 MainActivity.java: ```java public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Button openBrowserButton = findViewById(R.id.open_browser_button); openBrowserButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { String url = "https://www.example.com"; Intent intent = new Intent(Intent.ACTION_VIEW); intent.setData(Uri.parse(url)); startActivity(intent); } }); } } ``` 4. 通过 Intent 实现广播消息的接收: 在 MainActivity 中定义 Intent,并使用 sendBroadcast() 方法将广播消息发送出去。然后在 BroadcastReceiver 的 onReceive() 方法中接收广播消息,并使用 Toast 或 Logcat 打印出来。 MainActivity.java: ```java public class MainActivity extends AppCompatActivity { public static final String ACTION_MY_BROADCAST = "com.example.myapplication.ACTION_MY_BROADCAST"; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Button sendBroadcastButton = findViewById(R.id.send_broadcast_button); sendBroadcastButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { EditText editText = findViewById(R.id.edit_text); String message = editText.getText().toString(); Intent intent = new Intent(ACTION_MY_BROADCAST); intent.putExtra("message", message); sendBroadcast(intent); } }); } } ``` MyBroadcastReceiver.java: ```java public class MyBroadcastReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { String message = intent.getStringExtra("message"); Toast.makeText(context, message, Toast.LENGTH_SHORT).show(); Log.d("MyBroadcastReceiver", message); } } ``` AndroidManifest.xml: ```xml <receiver android:name=".MyBroadcastReceiver"> <intent-filter> <action android:name="com.example.myapplication.ACTION_MY_BROADCAST" /> </intent-filter> </receiver> ```

相关推荐

最新推荐

recommend-type

网络编程网络编程网络编程

网络编程网络编程网络编程网络编程
recommend-type

setuptools-5.4.zip

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

基于树莓派智能小车(H5页面操作移动+实时显示摄像头内容+各类传感器)源码+详细文档+全部资料齐全 高分项目.zip

【资源说明】 基于树莓派智能小车(H5页面操作移动+实时显示摄像头内容+各类传感器)源码+详细文档+全部资料齐全 高分项目.zip基于树莓派智能小车(H5页面操作移动+实时显示摄像头内容+各类传感器)源码+详细文档+全部资料齐全 高分项目.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这