如何在不关闭弹出窗口 activity 的情况下将数据传递给父窗口 activity?
How do I pass data from a popup activity to the parent activity without closing it?
private fun openPop(){
val intent = Intent(this, Pop::class.java)
startActivityForResult(intent,
PICK_VALUE_ANOTHER);
}
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
// Check which request we're responding to
if (requestCode == PICK_VALUE_ANOTHER) {
// Make sure the request was successful
if (resultCode == Activity.RESULT_OK) {
//Toast.makeText(this, "Data is ${data!!.data}", Toast.LENGTH_LONG).show()
title = data!!.getStringExtra("name")
}
}
}
我有打开弹出窗口的代码位置 activity。我可以使用结果,但我不希望它关闭,因为我想使用数据来增加字体大小。
弹出窗口中的代码如下activity
button3.setOnClickListener(View.OnClickListener {
val intent = intent
intent.putExtra("name", "Mr. Bean")
intent.putExtra("age", 85)
setResult(RESULT_OK, intent)
//finish()
})
所以,我有一个 ID 为 button3 的查看按钮,我确实获得了信息,但我想保持弹出窗口打开以发送更多信息,直到用户单击或点击弹出窗口 window.
我该怎么做?
谢谢
I want to do something or the same as the Amazon Kindle does as shown in the image
有一些方法可以实现。这是其中的三个,其中一个带有代码示例。
第一种方法
您可以在父 activity 和对话框之间使用共享视图模型。对话框正在更新字体大小,activity 正在观察这些变化并更新文本大小。
MainActivity.kt
class MainActivity : AppCompatActivity() {
private val vm: MainViewModel by viewModels()
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
val binding: MainActivityBinding =
DataBindingUtil.setContentView(this, R.layout.main_activity)
binding.adjustFontSizeButton.setOnClickListener {
AdjustFontDialog().show(supportFragmentManager, "dialog")
}
vm.fontSize.value = pxToSp(binding.text.textSize).toInt()
vm.fontSize.observe(this) {
binding.text.setTextSize(TypedValue.COMPLEX_UNIT_SP, it.toFloat());
}
}
private fun pxToSp(px: Float) = px / resources.displayMetrics.scaledDensity
}
main_activity.xml
<?xml version="1.0" encoding="utf-8"?>
<layout 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">
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="@dimen/margin"
tools:context=".MainActivity">
<TextView
android:id="@+id/text"
android:layout_width="0dp"
android:layout_height="0dp"
android:text="Hello World!"
android:textSize="20sp"
app:layout_constraintBottom_toTopOf="@+id/adjust_font_size_button"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<Button
android:id="@+id/adjust_font_size_button"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/margin"
android:text="@string/adjust_font_size"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/text" />
</androidx.constraintlayout.widget.ConstraintLayout>
</layout>
AdjustFontDialog.kt
class AdjustFontDialog : DialogFragment() {
private val vm: MainViewModel by activityViewModels()
override fun onCreateView(
inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?
) = AdjustFontDialogBinding.inflate(inflater, container, false).apply {
lifecycleOwner = viewLifecycleOwner
fontSizeSeekBar.progress = vm.fontSize.value ?: 0
fontSizeSeekBar.setOnSeekBarChangeListener(object : SeekBar.OnSeekBarChangeListener {
override fun onProgressChanged(seekBar: SeekBar, i: Int, b: Boolean) {
vm.fontSize.value = i
}
override fun onStartTrackingTouch(seekBar: SeekBar) {}
override fun onStopTrackingTouch(seekBar: SeekBar) {}
})
}.root
}
adjust_font_dialog.xml
<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:padding="@dimen/margin"
tools:context=".AdjustFontDialog">
<TextView
android:id="@+id/title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="@string/adjust_font_size" />
<SeekBar
android:id="@+id/font_size_seek_bar"
android:layout_width="200dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginTop="@dimen/margin"
android:max="60"
android:min="10" />
</LinearLayout>
</layout>
MainViewModel.kt
class MainViewModel : ViewModel() {
val fontSize = MutableLiveData<Int>()
}
build.gradle(应用模块)
apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-android-extensions'
apply plugin: 'kotlin-kapt'
android {
compileSdkVersion 29
buildToolsVersion "29.0.2"
defaultConfig {
applicationId "com.example.fontsize"
minSdkVersion 21
targetSdkVersion 29
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
dataBinding {
enabled true
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
kotlinOptions {
jvmTarget = JavaVersion.VERSION_1_8.toString()
}
}
dependencies {
implementation 'androidx.appcompat:appcompat:1.1.0'
implementation 'androidx.core:core-ktx:1.2.0'
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
implementation 'androidx.fragment:fragment:1.2.1'
implementation 'androidx.fragment:fragment-ktx:1.2.1'
implementation 'androidx.lifecycle:lifecycle-extensions:2.2.0'
implementation 'androidx.lifecycle:lifecycle-livedata-ktx:2.2.0'
implementation 'androidx.lifecycle:lifecycle-runtime-ktx:2.2.0'
implementation 'org.jetbrains.kotlin:kotlin-stdlib-jdk8:1.3.50'
//Testing
testImplementation 'junit:junit:4.12'
androidTestImplementation 'androidx.test.ext:junit:1.1.1'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'
}
第二种方法
在父级实现一个回调,让子级调用。参见 here。
第三种方法
使用采用 publisher/subscriber 模式的事件总线。参见 EventBus。
private fun openPop(){
val intent = Intent(this, Pop::class.java)
startActivityForResult(intent,
PICK_VALUE_ANOTHER);
}
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
// Check which request we're responding to
if (requestCode == PICK_VALUE_ANOTHER) {
// Make sure the request was successful
if (resultCode == Activity.RESULT_OK) {
//Toast.makeText(this, "Data is ${data!!.data}", Toast.LENGTH_LONG).show()
title = data!!.getStringExtra("name")
}
}
}
我有打开弹出窗口的代码位置 activity。我可以使用结果,但我不希望它关闭,因为我想使用数据来增加字体大小。
弹出窗口中的代码如下activity
button3.setOnClickListener(View.OnClickListener {
val intent = intent
intent.putExtra("name", "Mr. Bean")
intent.putExtra("age", 85)
setResult(RESULT_OK, intent)
//finish()
})
所以,我有一个 ID 为 button3 的查看按钮,我确实获得了信息,但我想保持弹出窗口打开以发送更多信息,直到用户单击或点击弹出窗口 window.
我该怎么做?
谢谢
I want to do something or the same as the Amazon Kindle does as shown in the image
有一些方法可以实现。这是其中的三个,其中一个带有代码示例。
第一种方法
您可以在父 activity 和对话框之间使用共享视图模型。对话框正在更新字体大小,activity 正在观察这些变化并更新文本大小。
MainActivity.kt
class MainActivity : AppCompatActivity() {
private val vm: MainViewModel by viewModels()
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
val binding: MainActivityBinding =
DataBindingUtil.setContentView(this, R.layout.main_activity)
binding.adjustFontSizeButton.setOnClickListener {
AdjustFontDialog().show(supportFragmentManager, "dialog")
}
vm.fontSize.value = pxToSp(binding.text.textSize).toInt()
vm.fontSize.observe(this) {
binding.text.setTextSize(TypedValue.COMPLEX_UNIT_SP, it.toFloat());
}
}
private fun pxToSp(px: Float) = px / resources.displayMetrics.scaledDensity
}
main_activity.xml
<?xml version="1.0" encoding="utf-8"?>
<layout 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">
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="@dimen/margin"
tools:context=".MainActivity">
<TextView
android:id="@+id/text"
android:layout_width="0dp"
android:layout_height="0dp"
android:text="Hello World!"
android:textSize="20sp"
app:layout_constraintBottom_toTopOf="@+id/adjust_font_size_button"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<Button
android:id="@+id/adjust_font_size_button"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/margin"
android:text="@string/adjust_font_size"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/text" />
</androidx.constraintlayout.widget.ConstraintLayout>
</layout>
AdjustFontDialog.kt
class AdjustFontDialog : DialogFragment() {
private val vm: MainViewModel by activityViewModels()
override fun onCreateView(
inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?
) = AdjustFontDialogBinding.inflate(inflater, container, false).apply {
lifecycleOwner = viewLifecycleOwner
fontSizeSeekBar.progress = vm.fontSize.value ?: 0
fontSizeSeekBar.setOnSeekBarChangeListener(object : SeekBar.OnSeekBarChangeListener {
override fun onProgressChanged(seekBar: SeekBar, i: Int, b: Boolean) {
vm.fontSize.value = i
}
override fun onStartTrackingTouch(seekBar: SeekBar) {}
override fun onStopTrackingTouch(seekBar: SeekBar) {}
})
}.root
}
adjust_font_dialog.xml
<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:padding="@dimen/margin"
tools:context=".AdjustFontDialog">
<TextView
android:id="@+id/title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="@string/adjust_font_size" />
<SeekBar
android:id="@+id/font_size_seek_bar"
android:layout_width="200dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginTop="@dimen/margin"
android:max="60"
android:min="10" />
</LinearLayout>
</layout>
MainViewModel.kt
class MainViewModel : ViewModel() {
val fontSize = MutableLiveData<Int>()
}
build.gradle(应用模块)
apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-android-extensions'
apply plugin: 'kotlin-kapt'
android {
compileSdkVersion 29
buildToolsVersion "29.0.2"
defaultConfig {
applicationId "com.example.fontsize"
minSdkVersion 21
targetSdkVersion 29
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
dataBinding {
enabled true
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
kotlinOptions {
jvmTarget = JavaVersion.VERSION_1_8.toString()
}
}
dependencies {
implementation 'androidx.appcompat:appcompat:1.1.0'
implementation 'androidx.core:core-ktx:1.2.0'
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
implementation 'androidx.fragment:fragment:1.2.1'
implementation 'androidx.fragment:fragment-ktx:1.2.1'
implementation 'androidx.lifecycle:lifecycle-extensions:2.2.0'
implementation 'androidx.lifecycle:lifecycle-livedata-ktx:2.2.0'
implementation 'androidx.lifecycle:lifecycle-runtime-ktx:2.2.0'
implementation 'org.jetbrains.kotlin:kotlin-stdlib-jdk8:1.3.50'
//Testing
testImplementation 'junit:junit:4.12'
androidTestImplementation 'androidx.test.ext:junit:1.1.1'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'
}
第二种方法
在父级实现一个回调,让子级调用。参见 here。
第三种方法
使用采用 publisher/subscriber 模式的事件总线。参见 EventBus。