From 7f900fcb347818eca3bd108e9575d44aba5157e1 Mon Sep 17 00:00:00 2001 From: p6zpjanrb <1157949412@qq.com> Date: Wed, 27 Dec 2023 21:11:36 +0800 Subject: [PATCH] Update AlarmAlertActivity.java --- .../micode/notes/ui/AlarmAlertActivity.java | 74 ++++++++++--------- 1 file changed, 40 insertions(+), 34 deletions(-) diff --git a/src/net/micode/notes/ui/AlarmAlertActivity.java b/src/net/micode/notes/ui/AlarmAlertActivity.java index b208e50..baa5f1e 100644 --- a/src/net/micode/notes/ui/AlarmAlertActivity.java +++ b/src/net/micode/notes/ui/AlarmAlertActivity.java @@ -14,6 +14,7 @@ * limitations under the License. */ + package net.micode.notes.ui; import android.app.Activity; @@ -39,10 +40,9 @@ import net.micode.notes.tool.DataUtils; import java.io.IOException; - public class AlarmAlertActivity extends Activity implements OnClickListener, OnDismissListener { - private long mNoteId; //文本在数据库存储中的ID号 - private String mSnippet; //闹钟提示时出现的文本片段 + private long mNoteId; //文本在数据库存储中的ID号 + private String mSnippet; //闹钟提示时出现的文本片段 private static final int SNIPPET_PREW_MAX_LEN = 60; MediaPlayer mPlayer; @@ -54,17 +54,17 @@ public class AlarmAlertActivity extends Activity implements OnClickListener, OnD //能从onCreate的参数savedInsanceState中获得状态数据 requestWindowFeature(Window.FEATURE_NO_TITLE); //界面显示——无标题 - + final Window win = getWindow(); win.addFlags(WindowManager.LayoutParams.FLAG_SHOW_WHEN_LOCKED); if (!isScreenOn()) { win.addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON - //保持窗体点亮 + //保持窗体点亮 | WindowManager.LayoutParams.FLAG_TURN_SCREEN_ON - //将窗体点亮 + //将窗体点亮 | WindowManager.LayoutParams.FLAG_ALLOW_LOCK_WHILE_SCREEN_ON - //允许窗体点亮时锁屏 + //允许窗体点亮时锁屏 | WindowManager.LayoutParams.FLAG_LAYOUT_INSET_DECOR); }//在手机锁屏后如果到了闹钟提示时间,点亮屏幕 @@ -83,7 +83,7 @@ public class AlarmAlertActivity extends Activity implements OnClickListener, OnD e.printStackTrace(); return; } - /* + /* try { // 代码区 @@ -93,26 +93,28 @@ public class AlarmAlertActivity extends Activity implements OnClickListener, OnD // 异常处理 } 代码区如果有错误,就会返回所写异常的处理。*/ - mPlayer = new MediaPlayer(); if (DataUtils.visibleInNoteDatabase(getContentResolver(), mNoteId, Notes.TYPE_NOTE)) { showActionDialog(); - //弹出对话框 + //弹出对话框 playAlarmSound(); - //闹钟提示音激发 + //闹钟提示音激发 } else { finish(); - //完成闹钟动作 + //完成闹钟动作 } } - private boolean isScreenOn() {//判断屏幕是否锁屏,调用系统函数判断,最后返回值是布尔类型 + private boolean isScreenOn() { + //判断屏幕是否锁屏,调用系统函数判断,最后返回值是布尔类型 PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE); return pm.isScreenOn(); } - private void playAlarmSound() {//闹钟提示音激发 - Uri url = RingtoneManager.getActualDefaultRingtoneUri(this, RingtoneManager.TYPE_ALARM);//调用系统的铃声管理URI,得到闹钟提示音 + private void playAlarmSound() { + //闹钟提示音激发 + Uri url = RingtoneManager.getActualDefaultRingtoneUri(this, RingtoneManager.TYPE_ALARM); + //调用系统的铃声管理URI,得到闹钟提示音 int silentModeStreams = Settings.System.getInt(getContentResolver(), Settings.System.MODE_RINGER_STREAMS_AFFECTED, 0); @@ -123,22 +125,22 @@ public class AlarmAlertActivity extends Activity implements OnClickListener, OnD } try { mPlayer.setDataSource(this, url); - //方法:setDataSource(Context context, Uri uri) - //解释:无返回值,设置多媒体数据来源 + //方法:setDataSource(Context context, Uri uri) + //解释:无返回值,设置多媒体数据来源【根据 Uri】 mPlayer.prepare(); - //准备同步 + //准备同步 mPlayer.setLooping(true); - //设置是否循环播放 + //设置是否循环播放 mPlayer.start(); - //开始播放 + //开始播放 } catch (IllegalArgumentException e) { // TODO Auto-generated catch block e.printStackTrace(); + //e.printStackTrace()函数功能是抛出异常, 还将显示出更深的调用信息 + //System.out.println(e),这个方法打印出异常,并且输出在哪里出现的异常 } catch (SecurityException e) { // TODO Auto-generated catch block e.printStackTrace(); - //e.printStackTrace()函数功能是抛出异常, 还将显示出更深的调用信息 - //System.out.println(e),这个方法打印出异常,并且输出在哪里出现的异常 } catch (IllegalStateException e) { // TODO Auto-generated catch block e.printStackTrace(); @@ -154,16 +156,15 @@ public class AlarmAlertActivity extends Activity implements OnClickListener, OnD //所以不能直接通过new一个AlertDialog来创建出一个AlertDialog。 //要创建一个AlertDialog,就要用到AlertDialog.Builder中的create()方法 //如这里的dialog就是新建了一个AlertDialog - dialog.setTitle(R.string.app_name); - //对话框设置标题 + //为对话框设置标题 dialog.setMessage(mSnippet); //为对话框设置内容 dialog.setPositiveButton(R.string.notealert_ok, this); - //给对话框添加“Yes”按钮 + //给对话框添加"Yes"按钮 if (isScreenOn()) { dialog.setNegativeButton(R.string.notealert_enter, this); - }//对话框添加“No”按钮 + }//对话框添加"No"按钮 dialog.show().setOnDismissListener(this); } @@ -171,33 +172,38 @@ public class AlarmAlertActivity extends Activity implements OnClickListener, OnD switch (which) { //用which来选择click后下一步的操作 case DialogInterface.BUTTON_NEGATIVE: + //这是取消操作 Intent intent = new Intent(this, NoteEditActivity.class); - //实现类间传输 + //实现两个类间的数据传输 intent.setAction(Intent.ACTION_VIEW); - //设置动作属性 + //设置动作属性 intent.putExtra(Intent.EXTRA_UID, mNoteId); + //实现key-value对 + //EXTRA_UID为key;mNoteId为键 startActivity(intent); - //开始动作 + //开始动作 break; default: + //这是确定操作 break; } } public void onDismiss(DialogInterface dialog) { + //忽略 stopAlarmSound(); - //停止闹钟声音 + //停止闹钟声音 finish(); - //完成该动作 + //完成该动作 } private void stopAlarmSound() { if (mPlayer != null) { mPlayer.stop(); - //停止播放 + //停止播放 mPlayer.release(); - //释放Player对象 + //释放MediaPlayer对象 mPlayer = null; } } -} +} \ No newline at end of file