android 炫酷倒计时连接数据库,并使用广播接收器的完整代码

时间: 2023-12-28 13:06:21 浏览: 33
以下是一个简单的 Android 炫酷倒计时应用的完整代码,其中包括了连接数据库和使用广播接收器的相关代码。 首先,我们需要创建一个数据库帮助类 `CountdownDBHelper`,用于创建和管理数据库: ```java public class CountdownDBHelper extends SQLiteOpenHelper { private static final String DATABASE_NAME = "countdown.db"; private static final int DATABASE_VERSION = 1; public static final String TABLE_COUNTDOWNS = "countdowns"; public static final String COLUMN_ID = "_id"; public static final String COLUMN_TITLE = "title"; public static final String COLUMN_DATE = "date"; private static final String CREATE_TABLE_COUNTDOWNS = "CREATE TABLE " + TABLE_COUNTDOWNS + "(" + COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_TITLE + " TEXT, " + COLUMN_DATE + " TEXT);"; public CountdownDBHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { db.execSQL(CREATE_TABLE_COUNTDOWNS); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { db.execSQL("DROP TABLE IF EXISTS " + TABLE_COUNTDOWNS); onCreate(db); } } ``` 接下来,我们需要创建一个 `Countdown` 类,用于表示一个倒计时对象,并实现相关的数据库操作: ```java public class Countdown { private long id; private String title; private Date date; public Countdown(long id, String title, Date date) { this.id = id; this.title = title; this.date = date; } public long getId() { return id; } public void setTitle(String title) { this.title = title; } public String getTitle() { return title; } public void setDate(Date date) { this.date = date; } public Date getDate() { return date; } public static List<Countdown> getAllCountdowns(Context context) { List<Countdown> countdowns = new ArrayList<>(); CountdownDBHelper dbHelper = new CountdownDBHelper(context); SQLiteDatabase db = dbHelper.getReadableDatabase(); Cursor cursor = db.query(CountdownDBHelper.TABLE_COUNTDOWNS, new String[]{CountdownDBHelper.COLUMN_ID, CountdownDBHelper.COLUMN_TITLE, CountdownDBHelper.COLUMN_DATE}, null, null, null, null, null); while (cursor.moveToNext()) { long id = cursor.getLong(cursor.getColumnIndex(CountdownDBHelper.COLUMN_ID)); String title = cursor.getString(cursor.getColumnIndex(CountdownDBHelper.COLUMN_TITLE)); String dateString = cursor.getString(cursor.getColumnIndex(CountdownDBHelper.COLUMN_DATE)); Date date = new Date(Long.parseLong(dateString)); countdowns.add(new Countdown(id, title, date)); } cursor.close(); db.close(); dbHelper.close(); return countdowns; } public static long addCountdown(Context context, String title, Date date) { CountdownDBHelper dbHelper = new CountdownDBHelper(context); SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put(CountdownDBHelper.COLUMN_TITLE, title); values.put(CountdownDBHelper.COLUMN_DATE, String.valueOf(date.getTime())); long id = db.insert(CountdownDBHelper.TABLE_COUNTDOWNS, null, values); db.close(); dbHelper.close(); return id; } public static void deleteCountdown(Context context, long id) { CountdownDBHelper dbHelper = new CountdownDBHelper(context); SQLiteDatabase db = dbHelper.getWritableDatabase(); db.delete(CountdownDBHelper.TABLE_COUNTDOWNS, CountdownDBHelper.COLUMN_ID + " = ?", new String[]{String.valueOf(id)}); db.close(); dbHelper.close(); } } ``` 接下来,我们需要创建一个 `CountdownAdapter` 类,用于将倒计时对象列表展示在 `RecyclerView` 中: ```java public class CountdownAdapter extends RecyclerView.Adapter<CountdownAdapter.ViewHolder> { private List<Countdown> countdowns; private Context context; public CountdownAdapter(Context context, List<Countdown> countdowns) { this.context = context; this.countdowns = countdowns; } public class ViewHolder extends RecyclerView.ViewHolder { public TextView titleTextView; public TextView countdownTextView; public ViewHolder(View itemView) { super(itemView); titleTextView = itemView.findViewById(R.id.titleTextView); countdownTextView = itemView.findViewById(R.id.countdownTextView); } } @Override public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { View itemView = LayoutInflater.from(parent.getContext()) .inflate(R.layout.list_item_countdown, parent, false); return new ViewHolder(itemView); } @Override public void onBindViewHolder(ViewHolder holder, int position) { Countdown countdown = countdowns.get(position); holder.titleTextView.setText(countdown.getTitle()); holder.countdownTextView.setText(getCountdownString(countdown.getDate())); } @Override public int getItemCount() { return countdowns.size(); } private String getCountdownString(Date date) { long diff = date.getTime() - new Date().getTime(); long days = TimeUnit.MILLISECONDS.toDays(diff); diff -= TimeUnit.DAYS.toMillis(days); long hours = TimeUnit.MILLISECONDS.toHours(diff); diff -= TimeUnit.HOURS.toMillis(hours); long minutes = TimeUnit.MILLISECONDS.toMinutes(diff); diff -= TimeUnit.MINUTES.toMillis(minutes); long seconds = TimeUnit.MILLISECONDS.toSeconds(diff); return String.format("%02dd %02dh %02dm %02ds", days, hours, minutes, seconds); } } ``` 接下来,我们需要创建一个 `CountdownActivity` 类,用于处理倒计时的各种操作: ```java public class CountdownActivity extends AppCompatActivity { private RecyclerView countdownRecyclerView; private CountdownAdapter countdownAdapter; private BroadcastReceiver countdownReceiver = new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { countdownAdapter.notifyDataSetChanged(); } }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_countdown); countdownRecyclerView = findViewById(R.id.countdownRecyclerView); countdownRecyclerView.setLayoutManager(new LinearLayoutManager(this)); List<Countdown> countdowns = Countdown.getAllCountdowns(this); countdownAdapter = new CountdownAdapter(this, countdowns); countdownRecyclerView.setAdapter(countdownAdapter); LocalBroadcastManager.getInstance(this).registerReceiver(countdownReceiver, new IntentFilter("countdown-updated")); FloatingActionButton addCountdownButton = findViewById(R.id.addCountdownButton); addCountdownButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { showAddCountdownDialog(); } }); } @Override protected void onDestroy() { super.onDestroy(); LocalBroadcastManager.getInstance(this).unregisterReceiver(countdownReceiver); } private void showAddCountdownDialog() { AlertDialog.Builder builder = new AlertDialog.Builder(this); builder.setTitle("Add Countdown"); View view = LayoutInflater.from(this).inflate(R.layout.dialog_add_countdown, null); final EditText titleEditText = view.findViewById(R.id.titleEditText); final DatePicker datePicker = view.findViewById(R.id.datePicker); final TimePicker timePicker = view.findViewById(R.id.timePicker); timePicker.setIs24HourView(true); builder.setView(view); builder.setPositiveButton("Add", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { String title = titleEditText.getText().toString(); Calendar calendar = Calendar.getInstance(); calendar.set(datePicker.getYear(), datePicker.getMonth(), datePicker.getDayOfMonth(), timePicker.getCurrentHour(), timePicker.getCurrentMinute()); long id = Countdown.addCountdown(CountdownActivity.this, title, calendar.getTime()); countdownAdapter.notifyDataSetChanged(); Intent intent = new Intent("countdown-updated"); LocalBroadcastManager.getInstance(CountdownActivity.this).sendBroadcast(intent); } }); builder.setNegativeButton("Cancel", null); builder.show(); } } ``` 最后,我们需要创建一个 `BroadcastReceiver` 类,用于在倒计时结束时发送通知: ```java public class CountdownReceiver extends BroadcastReceiver { private static final int NOTIFICATION_ID = 1; @Override public void onReceive(Context context, Intent intent) { NotificationManager notificationManager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); NotificationCompat.Builder builder = new NotificationCompat.Builder(context, "default") .setSmallIcon(R.drawable.ic_notification) .setContentTitle(intent.getStringExtra("title")) .setContentText("Countdown has ended!") .setPriority(NotificationCompat.PRIORITY_HIGH) .setAutoCancel(true); if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { NotificationChannel channel = new NotificationChannel("default", "Countdown", NotificationManager.IMPORTANCE_HIGH); notificationManager.createNotificationChannel(channel); } notificationManager.notify(NOTIFICATION_ID, builder.build()); } } ``` 以上就是一个简单的 Android 炫酷倒计时应用的完整代码,其中包括了连接数据库和使用广播接收器的相关代码。

相关推荐

最新推荐

recommend-type

C#中如何使用Winform实现炫酷的透明动画界面

讲解了如何使用Winform实现炫酷的透明动画界面,Winform相对于Wpf使用更简单一些,系统要求更低,需要了解的朋友可以参考下
recommend-type

C#实现炫酷启动图-动态进度条效果

主要介绍了基于C#实现炫酷启动图-动态进度条 效果,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

超炫酷的WPF实现Loading控件效果

主要介绍了超炫酷的WPF实现Loading控件效果,感兴趣的小伙伴们可以参考一下
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

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
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集群由多个称为代理的服务器组成,这