android - 在片段中创建日期选择器
问题描述
我刚开始学习 Kotlin,我目前的目标是在按下按钮后在片段中创建一个简单的日期选择器。
作为指南,我使用了该示例,由android developer docs for pickers显示。作为模板,我使用了底部导航标准模板。
我的问题:根据示例,我创建了一个类DatePickerFragment
。在返回行中,引用了一个需要上下文作为输入的方法。例子activity
中写了。我不知道要在这里实现什么才能使代码正常工作。
错误消息(参考类 DatePickerFragment):
- 'onCreateDialog' 不覆盖任何内容
- 类型不匹配:推断类型是 FragmentActivity?但上下文是预期的
在下面,我粘贴了一些代码。整个代码也可以在这里找到: https ://github.com/andregreschat/DatePickerinFragmentTest
DatePickerFragment 类:
package de.datepickerinfragmenttest
import android.app.DatePickerDialog
import android.app.Dialog
import android.os.Bundle
import android.view.View
import android.widget.DatePicker
import androidx.fragment.app.DialogFragment
import java.util.*
class DatePickerFragment : DialogFragment(), DatePickerDialog.OnDateSetListener {
override fun onCreateDialog(savedInstanceState: Bundle): Dialog {
// Use the current date as the default date in the picker
val c = Calendar.getInstance()
val year = c.get(Calendar.YEAR)
val month = c.get(Calendar.MONTH)
val day = c.get(Calendar.DAY_OF_MONTH)
// Create a new instance of DatePickerDialog and return it
return DatePickerDialog(activity, this, year, month, day)
}
override fun onDateSet(view: DatePicker, year: Int, month: Int, day: Int) {
// Do something with the date chosen by the user
}
}
主要活动
package de.datepickerinfragmenttest
import android.os.Bundle
import android.view.View
import com.google.android.material.bottomnavigation.BottomNavigationView
import androidx.appcompat.app.AppCompatActivity
import androidx.navigation.findNavController
import androidx.navigation.ui.AppBarConfiguration
import androidx.navigation.ui.setupActionBarWithNavController
import androidx.navigation.ui.setupWithNavController
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val navView: BottomNavigationView = findViewById(R.id.nav_view)
val navController = findNavController(R.id.nav_host_fragment)
// Passing each menu ID as a set of Ids because each
// menu should be considered as top level destinations.
val appBarConfiguration = AppBarConfiguration(setOf(
R.id.navigation_home, R.id.navigation_dashboard, R.id.navigation_notifications))
setupActionBarWithNavController(navController, appBarConfiguration)
navView.setupWithNavController(navController)
fun showDatePickerDialog(v: View) {
val newFragment = DatePickerFragment()
newFragment.show(supportFragmentManager, "datePicker")
}
}
}
分段:
package de.datepickerinfragmenttest.ui.home
import android.os.Bundle
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.widget.TextView
import androidx.fragment.app.Fragment
import androidx.lifecycle.Observer
import androidx.lifecycle.ViewModelProviders
import de.datepickerinfragmenttest.DatePickerFragment
import de.datepickerinfragmenttest.R
import androidx.fragment.app.FragmentManager
class HomeFragment : Fragment() {
private lateinit var homeViewModel: HomeViewModel
override fun onCreateView(
inflater: LayoutInflater,
container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
homeViewModel =
ViewModelProviders.of(this).get(HomeViewModel::class.java)
val root = inflater.inflate(R.layout.fragment_home, container, false)
val textView: TextView = root.findViewById(R.id.text_home)
homeViewModel.text.observe(viewLifecycleOwner, Observer {
textView.text = it
})
return root
}
}
带有按钮的片段布局
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".ui.home.HomeFragment">
<TextView
android:id="@+id/text_home"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="8dp"
android:layout_marginTop="8dp"
android:layout_marginEnd="8dp"
android:textAlignment="center"
android:textSize="20sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<Button
android:id="@+id/button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="SetDate"
app:layout_constraintBottom_toTopOf="@+id/text_home"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.5"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
android:onClick="showDatePickerDialog"/>
</androidx.constraintlayout.widget.ConstraintLayout>
解决方案
我有点想知道你正在设置你的navigation
组件,但是你没有使用它来移动到你的DialogFragment
.
在实例化对话框时activity
,您可能还需要调用2 种其他方法(而不是此属性)以获得所需的方法:Context
requireContext()
requireActivity()
(如果您需要确保某个活动Context
通过)
推荐阅读
- php - 使用 php 中的 API 访问 Google My Business Statistics
- reactjs - 将状态共享给其他组件 | 将数据传递给其他组件
- gitlab-ci-runner - Gitlab Runner 在启动下一个管道之前等待
- ansible - 使用带有 replace/lineinfile 模块的 ansible 删除 conf 文件中的重复条目
- jquery - 服务器通过 jQuery .ajax PATCH 请求获取 GET 请求
- java - 注入解析器实现取决于条件
- sms - Zapier 与 REX CRM 的集成
- laravel - 在 API 请求中发送数据的标准/通用/正确方式
- oauth-2.0 - 如何使用具有 pkce 授权类型的授权码模拟获取代码?
- angular - 克隆现有角度项目的问题