У меня есть ListView с элементами, созданными
val values = ArrayList<String>().toMutableList()
val adapter = ArrayAdapter(this, R.layout.listview_text_color, values)
adapter.add(title_editText.text!!.toString() + " - " + content_editText.text!!.toString())
Мне нужно сохранить эти элементы ListView и заново загрузить их при повторном открытии приложения с помощью SharedPreferences (не DB)
Это мойФактический код о SP:
fun saveData(values: Set<String>) {
val sharedPref = this.getPreferences(Context.MODE_PRIVATE) ?: return
with(sharedPref.edit()) {
putStringSet("test", values)
putString("title", title_editText.text!!.toString())
putString("content", content_editText.text!!.toString())
apply()
}
}
fun getData() {
val sharedPref = this.getPreferences(Context.MODE_PRIVATE) ?: return
val titleData = sharedPref.getString("title", "")
val contentData = sharedPref.getString("content", "")
Toast.makeText(this, "$titleData $contentData", Toast.LENGTH_LONG).show()
}
РЕДАКТИРОВАТЬ ДЛЯ РЕШЕНИЯ
После полных дней исследований я решил:
В MainActivity.kt создайте переменную ArrayList в качестве глобальной:
class MainActivity : AppCompatActivity() {
private var values = ArrayList<String>()
... //the rest of your code
}
Затем добавьте эти две функции:
private fun saveData() {
val sharedPreferences = getSharedPreferences("shared preferences", MODE_PRIVATE)
val editor = sharedPreferences.edit()
val gson = Gson()
val json = gson.toJson(values)
editor.putString("task list", json)
editor.apply()
}
private fun loadData() {
val sharedPreferences = getSharedPreferences("shared preferences", MODE_PRIVATE)
val gson = Gson()
val json = sharedPreferences.getString("task list", "")
val type = object: TypeToken<ArrayList<String>>() {
}.type
if(json == null)
values = ArrayList()
else
values = gson.fromJson(json, type)
}
, где values
- ваш ArrayList
Для сохранения данных:
done_fab.setOnClickListener {
values.add("put your string here")
adapter.notifyDataSetChanged() //your array adapter
saveData()
}
А чтобы загрузить данные, просто вызовите функцию в MainActivity:
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
loadData()
val adapter = ArrayAdapter(this, R.layout.listview_text_color, values) //your custom arrayAdapter for the listView
... //the rest of your code
}