前提
android studioでデータ使用量を確認するアプリを作っています。
データ使用量をtextviewに表示することはできたのですが、アプリを再起動しないとデータ使用量の数字が更新されません。(何故か画面を回転してみたら更新された)
実現したいこと
- データ使用量のtextviewが自動で更新されるようにしたい。
該当のソースコード (MainActivity.kt)
kotlin
1package io.github.takogori.datausage 2 3import android.annotation.SuppressLint 4import android.app.AppOpsManager 5import android.app.usage.NetworkStatsManager 6import android.content.Context 7import android.content.Intent 8import android.net.ConnectivityManager 9import android.os.Bundle 10import android.os.Process 11import android.provider.Settings 12import android.widget.TextView 13import androidx.appcompat.app.AppCompatActivity 14import java.util.* 15 16class MainActivity : AppCompatActivity() { 17 18 override fun onCreate(savedInstanceState: Bundle?) { 19 super.onCreate(savedInstanceState) 20 setContentView(R.layout.activity_main) 21 22 val textView = findViewById<TextView>(R.id.activity_main_text_view) 23 24 if (checkUsageStatsPermission()) { 25 // 権限がある 26 val byte = getMobileDataUsageFromCurrentMonth() 27 // MBへ変換。Byte -> KB -> MB 28 val usageMB = byte / 1024f / 1024f 29 // TextViewに入れる 30 val usageMBkirisute = Math.round(usageMB) 31 textView.text = "$usageMBkirisute MB" 32 33 } else { 34 // ない 35 startActivity(Intent(Settings.ACTION_USAGE_ACCESS_SETTINGS)) 36 } 37 } 38 /** 39 * PACKAGE_USAGE_STATSの権限が付与されているか確認する 40 * @return 権限があればtrue 41 * */ 42 fun checkUsageStatsPermission(): Boolean { 43 val appOpsManager = getSystemService(APP_OPS_SERVICE) as AppOpsManager 44 val mode = if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.Q) { 45 // Android 10 以降 46 appOpsManager.unsafeCheckOpNoThrow( 47 AppOpsManager.OPSTR_GET_USAGE_STATS, 48 Process.myUid(), 49 application.packageName 50 ) 51 } else { 52 // Android 9 以前 53 appOpsManager.checkOpNoThrow( 54 AppOpsManager.OPSTR_GET_USAGE_STATS, 55 Process.myUid(), 56 application.packageName 57 ) 58 } 59 return mode == AppOpsManager.MODE_ALLOWED 60 } 61 62 /** 63 * 今月のモバイルデータ利用量を取得する。単位はバイト 64 * @return バイト単位で返す 65 * */ 66 @SuppressLint("ServiceCast") 67 68 fun getMobileDataUsageFromCurrentMonth(): Long { 69 val networkStatsManager = 70 getSystemService(Context.NETWORK_STATS_SERVICE) as NetworkStatsManager 71 // 集計開始の日付その月の最初の日 72 val startTime = Calendar.getInstance().apply { 73 set(Calendar.DAY_OF_MONTH, 1) 74 set(Calendar.HOUR_OF_DAY, 0) 75 set(Calendar.MINUTE, 0) 76 set(Calendar.SECOND, 0) 77 }.time.time 78 // 集計終了は現在時刻 79 val endTime = Calendar.getInstance().time.time 80 // 問い合わせる 81 val bucket = networkStatsManager.querySummaryForDevice( 82 ConnectivityManager.TYPE_MOBILE, 83 null, 84 startTime, 85 endTime 86 ) 87 // 送信 + 受信 88 return bucket.txBytes + bucket.rxBytes 89 90 } 91 92 }
補足情報(FW/ツールのバージョンなど)
Android Studioのバージョン:Android Studio Chipmunk | 2021.2.1 Patch 2
使用している言語:kotlin
min sdk version:API23 Android6.0 (Marshmallow)
使用している実機:Pixel5a(android12)
回答2件
あなたの回答
tips
プレビュー