Kotlin, менеджер аварийных сигналов не срабатывает - PullRequest
0 голосов
/ 10 февраля 2019

Я перепробовал много примеров, в том числе, например, в документации для Android, но ни один из них не сработал.

Вот мой код:

package wentaas.odaklan

import android.annotation.SuppressLint
import android.app.*
import android.os.Bundle
import android.support.v7.app.AppCompatActivity
import android.text.Layout
import android.text.format.DateFormat
import android.util.TypedValue
import android.view.Gravity
import android.view.View
import android.view.View.TEXT_ALIGNMENT_CENTER
import android.view.View.VISIBLE
import android.view.ViewGroup
import android.view.ViewGroup.LayoutParams.WRAP_CONTENT
import kotlinx.android.synthetic.main.activity_main.*
import android.content.Context.ALARM_SERVICE
import android.support.v4.content.ContextCompat.getSystemService
import android.content.BroadcastReceiver
import android.content.Context
import android.content.Intent
import android.support.v4.content.ContextCompat.startActivity
import android.support.v4.content.IntentCompat
import android.content.Intent.makeRestartActivityTask
import android.content.ComponentName
import android.content.pm.PackageManager
import android.os.Build
import android.os.PowerManager
import android.support.v4.app.NotificationCompat
import android.support.v4.app.NotificationManagerCompat
import android.widget.*
import java.util.*

//fun makeAlarms(context: Context) {
//    val t = TinyDB(context)
//    val hour = t.getListInt("hour")
//    val minute = t.getListInt("minute")
//
//    Toast.makeText(context.applicationContext, "$hour\n$minute", Toast.LENGTH_SHORT).show()
//
//    var i = 0
//    for (item in hour) {
//        val alarmMgr = context.getSystemService(Context.ALARM_SERVICE) as AlarmManager
//        val alarmIntent = Intent(context, MainActivity::class.java).let { intent ->
//            PendingIntent.getBroadcast(context, 0, intent, 0)
//        }
//
//        alarmMgr.cancel(alarmIntent)
//
//        val calendar = Calendar.getInstance().apply {
//            timeInMillis = System.currentTimeMillis()
//            set(Calendar.HOUR_OF_DAY, hour[i])
//            set(Calendar.MINUTE, minute[i])
//        }
//        alarmMgr.setInexactRepeating(AlarmManager.RTC_WAKEUP, calendar.timeInMillis, AlarmManager.INTERVAL_DAY, alarmIntent)
//
//        i += 1
//    }
//}

class MainActivity : AppCompatActivity() {

    @SuppressLint("SetTextI18n")
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
//        setSupportActionBar(toolbar)
//
//        val t = TinyDB(this)
//        t.clear()
//        val is24 = DateFormat.is24HourFormat(this)
//        var hour = t.getListInt("hour")
//        var minute = t.getListInt("minute")
//
        val am = this.getSystemService(Context.ALARM_SERVICE) as AlarmManager
        val date = Date()
        val alarmCal = Calendar.getInstance()
        val nowCal = Calendar.getInstance()
        nowCal.time = date
        alarmCal.time = date
        alarmCal.set(Calendar.HOUR_OF_DAY, 10)
        alarmCal.set(Calendar.MINUTE, 55)
        alarmCal.set(Calendar.SECOND, 0)
        val intent = Intent(this, AlarmReceiver::class.java)
        val pendingIntent = PendingIntent.getBroadcast(this, 0, intent, 0)
        am.setRepeating(AlarmManager.RTC_WAKEUP, alarmCal.timeInMillis, 1000*60, pendingIntent)
//
//        fun put() {
//            t.putListInt("hour", hour)
//            t.putListInt("minute", minute)
//        }
//
//        if (hour.isEmpty() || minute.isEmpty()) {
//            hour.clear()
//            minute.clear()
//            hour.add(10)
//            minute.add(30)
//            put()
//        }
//
//        fun toText(hour: Int, minute: Int): String {
//            if (is24) {
//                val hourText = when (hour) {
//                    in 0..9 -> "0$hour"
//                    else -> "$hour"
//                }
//                val minuteText = when (minute) {
//                    in 0..9 -> "0$minute"
//                    else -> "$minute"
//                }
//                return "$hourText:$minuteText"
//            } else {
//                val hourText: String
//                val ampm: String
//                when (hour) {
//                    0 -> {
//                        hourText = "12"
//                        ampm = "AM"
//                    }
//                    in 1..9 -> {
//                        hourText = "0$hour"
//                        ampm = "AM"
//                    }
//                    in 10..12 -> {
//                        hourText = "$hour"
//                        ampm = "AM"
//                    }
//                    in 13..23 -> {
//                        hourText = "${hour - 12}"
//                        ampm = "PM"
//                    }
//                    else -> {
//                        hourText = "$hour"
//                        ampm = "AM"
//                    }
//                }
//                val minuteText = when (minute) {
//                    in 0..9 -> "0$minute"
//                    else -> "$minute"
//                }
//                return "$hourText:$minuteText $ampm"
//            }
//        }
//
//        fun load() {
//
//            hour = t.getListInt("hour")
//            minute = t.getListInt("minute")
//            val time = mutableListOf<Button>()
//
//            for (item in layout.touchables) {
//                layout.removeView(item)
//            }
//
//            var i = 0
//            for (item in hour) {
//                val button = Button(this)
//
//                button.setTextSize(TypedValue.COMPLEX_UNIT_SP, 30F)
//                val p = LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT)
//                p.gravity = Gravity.CENTER
//                button.layoutParams = p
//                button.gravity = Gravity.CENTER
//
//                time.add(button)
//                layout.addView(button)
//
//                i += 1
//            }
//
//            makeAlarms(this)
//
//
//            text.text = "$hour\n$minute\n$time\n${t.getListInt("hour")}\n${t.getListInt("minute")}"
//
//            i = 0
//            for (item in time) {
//                time[i].text = toText(hour[i], minute[i])
//                time[i].setOnClickListener {
//                    val w = time.indexOf(it)
//
//                    val timePickerDialog = TimePickerDialog(
//                        this@MainActivity, R.style.CustomDatePickerDialog,
//                        TimePickerDialog.OnTimeSetListener {_, sHour, sMinute ->
//                            hour[w] = sHour
//                            minute[w] = sMinute
//
//                            put()
//                            load()
//                        }, hour[w], minute[w], is24)
//                    timePickerDialog.show()
//
//                    val deleteButton = timePickerDialog.getButton(Dialog.BUTTON_NEUTRAL)
//                    deleteButton.text = getString(R.string.delete)
//                    if (w == 0) {
//                        deleteButton.isEnabled = false
//                    }
//                    deleteButton.visibility = VISIBLE
//                    deleteButton.setOnClickListener {
//                        hour.removeAt(w)
//                        minute.removeAt(w)
//
//                        put()
//                        timePickerDialog.dismiss()
//                        load()
//                    }
//                }
//                i += 1
//            }
//        }
//
//        fab.setOnClickListener {
//            val timePickerDialog = TimePickerDialog(
//                this@MainActivity, R.style.CustomDatePickerDialog,
//                TimePickerDialog.OnTimeSetListener {_, sHour, sMinute ->
//                    hour.add(sHour)
//                    minute.add(sMinute)
//
//                    put()
//                    load()
//                }, hour.last(), minute.last(), is24)
//            timePickerDialog.show()
//        }
//
////        load()
//    }
//}
//
//class BootReceiver : BroadcastReceiver() {
//
//    override fun onReceive(context: Context, intent: Intent) {
//        if (intent.action == "android.intent.action.BOOT_COMPLETED") {
//            makeAlarms(context)
//        }
    }
}
//
class AlarmReceiver: BroadcastReceiver() {

    override fun onReceive(context:Context, intent:Intent) {

        val pm = context.getSystemService(Context.POWER_SERVICE) as PowerManager
        val wl = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "1:")

        wl.acquire(10*60*1000L)

        Toast.makeText(context, "Alarm !!!!!!!!!!", Toast.LENGTH_LONG).show()

        wl.release()
//
//        val builder = NotificationCompat.Builder(context, "1")
//            .setSmallIcon(R.mipmap.ic_launcher_round)
//            .setContentTitle(context.getString(R.string.title))
//            .setContentText(context.getString(R.string.text))
//
//        NotificationManagerCompat.from(context).notify(1, builder.build())
    }
}

Я включилкомментарии, если они имеют значение вообще.Это не дает никаких ошибок, это только не вызывает.Я пробовал этот код с 10:53 до 10: 56.

Вот мой манифест:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
          xmlns:tools="http://schemas.android.com/tools"
          package="wentaas.odaklan">

    <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>

    <application
            android:allowBackup="true"
            android:icon="@mipmap/ic_launcher"
            android:label="@string/app_name"
            android:roundIcon="@mipmap/ic_launcher_round"
            android:supportsRtl="true"
            android:theme="@style/AppTheme"
            tools:ignore="GoogleAppIndexingWarning">
        <activity
                android:name=".MainActivity"
                android:label="@string/app_name"
                android:theme="@style/AppTheme.NoActionBar">
            <intent-filter>
                <action android:name="android.intent.action.MAIN"/>
                <category android:name="android.intent.category.LAUNCHER"/>
            </intent-filter>
        </activity>
        <!--<receiver android:name=".BootReceiver"-->
                  <!--android:enabled="true">-->
            <!--<intent-filter>-->
                <!--<action android:name="android.intent.action.BOOT_COMPLETED">-->

                <!--</action>-->
            <!--</intent-filter>-->
        <!--</receiver>-->
        <receiver android:name=".AlarmReceiver">
        </receiver>
    </application>

</manifest>

Заранее спасибо.Любая помощь могла бы быть полезна.Я схожу с ума по этому!

...