Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Activity #1 #34

Open
wants to merge 3 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions app/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -52,4 +52,5 @@ dependencies {
implementation 'androidx.core:core-ktx:1.8.0'
implementation 'androidx.appcompat:appcompat:1.5.0'
implementation 'com.google.android.material:material:1.6.1'
implementation 'androidx.constraintlayout:constraintlayout:2.1.4'
}
24 changes: 23 additions & 1 deletion app/src/main/AndroidManifest.xml
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,28 @@
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/Theme.Activities"
tools:targetApi="31" />
tools:targetApi="31">

<activity android:name=".ActivityB"
android:exported="false"/>

<activity android:name=".ActivityC"
android:exported="false" />

<activity android:name=".ActivityD"
android:exported="false" />


<activity
android:name=".ActivityA"
android:exported="true"
android:launchMode="singleTask">
<intent-filter>
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@NanaOz , я бы использовал тут режим запуска singleTask. Почему:

  1. Задание 1: при этом предусмотрите возможность открывать другие Activity в том же стеке где расположена ActivityA
  2. Задание 3: По клику на кнопку “Open ActivityA” запустите ActivityA, таким образом, чтобы мы попали на существующий экземпляр ActivityA и у него был вызван метод onNewIntent

В таком случае, мы можем и создавать активити выше по стеку в этой задаче и возвращаться в наш экземплят. Синглтоп, что вы используете во флагах вернется в тот же экземпляр только если он на верху стэка. А если он чем-то накрыт, то будет пересоздан. Вот тут, мне кажется, неплохая статейка с примерами

<action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>

</manifest>
29 changes: 29 additions & 0 deletions app/src/main/java/otus/gpb/homework/activities/ActivityA.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
package otus.gpb.homework.activities

import android.content.Intent
import android.os.Bundle
import android.util.Log
import android.widget.Button
import androidx.appcompat.app.AppCompatActivity

class ActivityA : AppCompatActivity() {

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_a)

val openActivityBButton = findViewById<Button>(R.id.btn_activity_a)
openActivityBButton.setOnClickListener {
// Обработка нажатия на кнопку "Open ActivityB"
val intent = Intent(this, ActivityB::class.java)
//intent.flags = Intent.FLAG_ACTIVITY_NEW_TASK or Intent.FLAG_ACTIVITY_CLEAR_TASK
startActivity(intent)
}
}

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@NanaOz, добавьте сюда, пожалуйста, переопределение метода onNewIntent с каким-нибудь логированием типа:

        Log.w("A", "New intent")

Таким образом, вы сможете проверить выполнение задания 3

override fun onNewIntent(intent: Intent?) {
Log.w("ActivityA", "call new intent activityA")
super.onNewIntent(intent)

}
}
21 changes: 21 additions & 0 deletions app/src/main/java/otus/gpb/homework/activities/ActivityB.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
package otus.gpb.homework.activities

import android.content.Intent
import android.os.Bundle
import android.widget.Button
import androidx.appcompat.app.AppCompatActivity

class ActivityB : AppCompatActivity() {

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_b)

val openActivityCButton = findViewById<Button>(R.id.btn_activity_b)
openActivityCButton.setOnClickListener {
// Обработка нажатия на кнопку "Open ActivityC"
val intent = Intent(this, ActivityC::class.java)
startActivity(intent)
}
}
}
46 changes: 46 additions & 0 deletions app/src/main/java/otus/gpb/homework/activities/ActivityC.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
package otus.gpb.homework.activities

import android.content.Intent
import android.os.Bundle
import android.widget.Button
import androidx.appcompat.app.AppCompatActivity

class ActivityC : AppCompatActivity() {

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_c)

val openActivityAButton = findViewById<Button>(R.id.btn_activity_c_open_a)
openActivityAButton.setOnClickListener {
// Обработка нажатия на кнопку "Open ActivityA"
val intent = Intent(this, ActivityA::class.java)
//intent.flags = Intent.FLAG_ACTIVITY_SINGLE_TOP
startActivity(intent)
}

val openActivityDButton = findViewById<Button>(R.id.btn_activity_c_open_d)
openActivityDButton.setOnClickListener {
// Обработка нажатия на кнопку "Open ActivityD"

val intent = Intent(this, ActivityD::class.java)
intent.flags = Intent.FLAG_ACTIVITY_CLEAR_TOP or Intent.FLAG_ACTIVITY_NEW_TASK
startActivity(intent)
}

val closeActivityCButton = findViewById<Button>(R.id.btn_activity_c_close_c)
closeActivityCButton.setOnClickListener {
// Обработка нажатия на кнопку "Close ActivityC"
finish()
}

val closeStackButton = findViewById<Button>(R.id.btn_activity_c_close_stack)
closeStackButton.setOnClickListener {
// Обработка нажатия на кнопку "Close Stack"
val intent = Intent(this, ActivityA::class.java)
intent.flags = Intent.FLAG_ACTIVITY_NEW_TASK or Intent.FLAG_ACTIVITY_CLEAR_TASK
startActivity(intent)
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@NanaOz, отлично! Это совместимый метод. Но рекомендую еще посмотреть метод finishAffinity

finishAffinity()
}
}
}
11 changes: 11 additions & 0 deletions app/src/main/java/otus/gpb/homework/activities/ActivityD.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
package otus.gpb.homework.activities

import android.os.Bundle
import androidx.appcompat.app.AppCompatActivity

class ActivityD : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_d)
}
}
19 changes: 19 additions & 0 deletions app/src/main/res/layout/activity_a.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
<?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"
android:background="#f44336">

<Button
android:id="@+id/btn_activity_a"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/button"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
tools:ignore="MissingConstraints" />
</androidx.constraintlayout.widget.ConstraintLayout>
21 changes: 21 additions & 0 deletions app/src/main/res/layout/activity_b.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
<?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"
android:background="#4caf50">

<Button
android:id="@+id/btn_activity_b"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/open_activityc"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.796"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.691"
tools:ignore="MissingConstraints" />
</androidx.constraintlayout.widget.ConstraintLayout>
51 changes: 51 additions & 0 deletions app/src/main/res/layout/activity_c.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
<?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"
android:background="#2196f3">

<Button
android:id="@+id/btn_activity_c_open_a"
android:layout_width="176dp"
android:layout_height="50dp"
android:layout_marginStart="64dp"
android:layout_marginTop="304dp"
android:text="@string/open_activitya"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />

<Button
android:id="@+id/btn_activity_c_close_c"
android:layout_width="176dp"
android:layout_height="50dp"
android:layout_marginStart="64dp"
android:layout_marginTop="8dp"
android:text="@string/close_activityc"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/btn_activity_c_open_d" />

<Button
android:id="@+id/btn_activity_c_close_stack"
android:layout_width="176dp"
android:layout_height="50dp"
android:layout_marginStart="64dp"
android:layout_marginBottom="192dp"
android:text="@string/close_stack"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/btn_activity_c_close_c"
app:layout_constraintVertical_bias="0.294" />

<Button
android:id="@+id/btn_activity_c_open_d"
android:layout_width="176dp"
android:layout_height="50dp"
android:layout_marginStart="64dp"
android:layout_marginTop="8dp"
android:text="@string/open_activityd"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/btn_activity_c_open_a" />

</androidx.constraintlayout.widget.ConstraintLayout>
16 changes: 16 additions & 0 deletions app/src/main/res/layout/activity_d.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
<?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"
android:background="#ffeb3b">

<TextView
android:id="@+id/textView_activiti_d"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/activity_d"
tools:layout_editor_absoluteX="73dp"
tools:layout_editor_absoluteY="240dp" />
</androidx.constraintlayout.widget.ConstraintLayout>
7 changes: 7 additions & 0 deletions app/src/main/res/values/strings.xml
Original file line number Diff line number Diff line change
@@ -1,3 +1,10 @@
<resources>
<string name="app_name">Activities</string>
<string name="button">Open ActivityB</string>
<string name="close_activityc">Close ActivityC</string>
<string name="close_stack">Close Stack</string>
<string name="open_activityd">Open ActivityD</string>
<string name="open_activitya">Open ActivityA</string>
<string name="open_activityc">Open ActivityC</string>
<string name="activity_d">Это активити Д)</string>
</resources>
4 changes: 2 additions & 2 deletions build.gradle
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// Top-level build file where you can add configuration options common to all sub-projects/modules.
plugins {
id 'com.android.application' version '7.2.0' apply false
id 'com.android.library' version '7.2.0' apply false
id 'com.android.application' version '7.4.0' apply false
id 'com.android.library' version '7.4.0' apply false
id 'org.jetbrains.kotlin.android' version '1.6.21' apply false
id "io.gitlab.arturbosch.detekt" version "1.21.0"
}
Expand Down
2 changes: 1 addition & 1 deletion gradle/wrapper/gradle-wrapper.properties
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#Sat Aug 27 13:57:30 MSK 2022
distributionBase=GRADLE_USER_HOME
distributionUrl=https\://services.gradle.org/distributions/gradle-7.3.3-bin.zip
distributionUrl=https\://services.gradle.org/distributions/gradle-7.5-bin.zip
distributionPath=wrapper/dists
zipStorePath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME