AS中級 値の受け渡し編②解説~Activityから別のActivityへ配列、List(コレクション)、オブジェクトを渡す~

Try1.の解答例

 

MainActivity.java

package com.example.arraytransition;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class MainActivity extends AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

int[] intArray = new int[]{3,7,5};

Button nextBtn = findViewById(R.id.nextBtn);
nextBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(MainActivity.this,SecondActivity.class);
intent.putExtra("array",intArray);
startActivity(intent);
}
});


}
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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=".MainActivity"
android:gravity="center_horizontal"
android:orientation="vertical">

<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="int型の配列 {3,7,5}"
android:layout_marginTop="60sp"/>

<Button
android:id="@+id/nextBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="次ページへ遷移"
android:layout_marginTop="40sp"/>

</LinearLayout>

SecondActivity.java

package com.example.arraytransition;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.os.Bundle;
import android.widget.TextView;

public class SecondActivity extends AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_second);

Intent intent = getIntent();
int[] intArrayTake = intent.getIntArrayExtra("array");

TextView secondView = findViewById(R.id.secondView);
String viewText = "{" + intArrayTake[0] + "," + intArrayTake[1]+"," + intArrayTake[2] + "}";
secondView.setText(viewText);
}
}

activity_second.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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=".SecondActivity"
android:gravity="center_horizontal">

<TextView
android:id="@+id/secondView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="30sp"
android:layout_marginTop="160sp"/>

</LinearLayout>

 

 

Try2の解答例

 

MainActivity.java

package com.example.arraytransition2;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

ArrayList<Nameage> nameageList = new ArrayList<>();
nameageList.add(new Nameage("yamada",29));
nameageList.add(new Nameage("satou",34));
nameageList.add(new Nameage("suzuki",67));

TextView firstView = findViewById(R.id.firstView);
StringBuilder firstStrBld = new StringBuilder();
for(Nameage nameage:nameageList){
firstStrBld.append(nameage.getName()).append(" ").append(nameage.getAge()).append("\n");
}
firstView.setText(firstStrBld.toString());

Button nextBtn = findViewById(R.id.nextBtn);
nextBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(MainActivity.this,SecondActivity.class);
intent.putParcelableArrayListExtra("list",nameageList);
startActivity(intent);
}
});


}
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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=".MainActivity"
android:gravity="center_horizontal"
android:orientation="vertical">

<TextView
android:id="@+id/firstView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>

<Button
android:id="@+id/nextBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="次ページへ"/>

</LinearLayout>

SecondActivity.java

package com.example.arraytransition2;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.os.Bundle;
import android.widget.TextView;

import java.util.ArrayList;

public class SecondActivity extends AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_second);

Intent intent = getIntent();
ArrayList<Nameage> arrayList = intent.getParcelableArrayListExtra("list");

TextView secondView = findViewById(R.id.secondView);
StringBuilder strBld = new StringBuilder();
for(Nameage nameage:arrayList){
strBld.append(nameage.getName()).append(" ").append(String.valueOf(nameage.getAge())).append("\n");
}

secondView.setText(strBld.toString());
}
}

activity_second.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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=".SecondActivity"
android:gravity="center_horizontal">

<TextView
android:id="@+id/secondView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="80sp"/>

</LinearLayout>

Nameage.java

package com.example.arraytransition2;

import android.os.Parcel;
import android.os.Parcelable;

public class Nameage implements Parcelable {
private String name;
private int age;

public Nameage(String name, int age) {
this.name = name;
this.age = age;
}

protected Nameage(Parcel in) {
name = in.readString();
age = in.readInt();
}

@Override
public void writeToParcel(Parcel dest, int flags) {
dest.writeString(name);
dest.writeInt(age);
}

@Override
public int describeContents() {
return 0;
}

public static final Creator<Nameage> CREATOR = new Creator<Nameage>() {
@Override
public Nameage createFromParcel(Parcel in) {
return new Nameage(in);
}

@Override
public Nameage[] newArray(int size) {
return new Nameage[size];
}
};

public String getName() { return name; }

public void setName(String name) {
this.name = name;
}

public int getAge() {
return age;
}

public void setAge(int age) {
this.age = age;
}
}

 

Try3の解答例

softwarenote.info

 

 

AS中級 値の受け渡し編②問題~Activityから別のActivityへ配列、List(コレクション)、オブジェクトを渡す~

Try1. 配列型変数(配列)を、MainActivityからSecondActivityに送るアプリを作ってみましょう。

 

Try2. name(String型)とage(int型)をメンバーとするNameageクラスを作成し、そのList(コレクション)を、MainActivityからSecondActivityに送るアプリを作ってみましょう。

 

Try3. name(String型)とage(int型)をメンバーとするNameageクラスを作成し、name = "yamada"  、 age= "29" としたNameageクラスのオブジェクトを、

MainActivityからSecondActivityへ送るアプリを作ってみましょう。

AS中級 値の受け渡し編①解説~Activityから別のActivityへ値を渡す~

Try1の解答例

MainActivity.java

package com.example.gettakea2a;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);


EditText xEdit = findViewById(R.id.xEdit);
EditText yEdit = findViewById(R.id.yEdit);
TextView frontNumber = findViewById(R.id.frontNumber);
TextView backNumber = findViewById(R.id.backNumber);
Button inputNextBtn = findViewById(R.id.inputNextBtn);


inputNextBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
int x = Integer.parseInt(xEdit.getText().toString());
int y = Integer.parseInt(yEdit.getText().toString());
int result = x + y;
Intent intent = new Intent(MainActivity.this,SecondActivity.class);
intent.putExtra("result",result); ・・・・・・・・・①
startActivity(intent);
}
});
}
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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=".MainActivity"
android:orientation="vertical"
android:gravity="center_horizontal">


<TextView
android:id="@+id/frontNumber"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="x"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="+"/>
<TextView
android:id="@+id/backNumber"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="y"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="= ?"/>

<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="xに代入する値"
android:layout_margin="40sp"/>
<EditText
android:id="@+id/xEdit"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text=""/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="yに代入する値"
android:layout_margin="40sp"/>
<EditText
android:id="@+id/yEdit"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text=""/>
<Button
android:id="@+id/inputNextBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="結果は次ページ"/>

</LinearLayout>

SecondActivity.java

package com.example.gettakea2a;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.os.Bundle;
import android.widget.TextView;

public class SecondActivity extends AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_second);

TextView resultNumber = findViewById(R.id.resultNumber);

Intent intent = getIntent();
int resultNum = intent.getIntExtra("result",0);    ・・・・・・②
resultNumber.setText(String.valueOf(resultNum));
}
}

activity_second.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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=".SecondActivity"
android:gravity="center_horizontal"
android:orientation="vertical">

<TextView
android:id="@+id/resultNumber"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="200sp"
android:textSize="30sp"/>

</LinearLayout>

 

Try2の解答例

MainActivity.java

package com.example.a2a;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;

public class MainActivity extends AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

EditText frontEdit = findViewById(R.id.frontEdit);
EditText backEdit = findViewById(R.id.backEdit);
StringBuilder stringBuilder = new StringBuilder();

Button fusionNextBtn = findViewById(R.id.fusionNextBtn);
fusionNextBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {

stringBuilder.append(frontEdit.getText().toString())
.append(backEdit.getText().toString());
String resultStr = stringBuilder.toString();
//Log.v("MY_LOG",resultStr);
Intent intent = new Intent(MainActivity.this,SecondActivity.class);
intent.putExtra("resultStr",resultStr);
startActivity(intent);
}
});
}
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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=".MainActivity"
android:gravity="center_horizontal"
android:orientation="vertical">

<EditText
android:id="@+id/frontEdit"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="40sp"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="+"
android:textSize="30sp"/>
<EditText
android:id="@+id/backEdit"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
<Button
android:id="@+id/fusionNextBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="合体して次ページへ"/>


</LinearLayout>
 

SecondActivity.java

package com.example.a2a;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.os.Bundle;
import android.widget.TextView;

public class SecondActivity extends AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_second);

TextView resultView = findViewById(R.id.resultView);

Intent intent = getIntent();
String resultString = intent.getStringExtra("resultStr");
resultView.setText(resultString);
}
}

activity_second.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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=".SecondActivity"
android:gravity="center_horizontal"
android:orientation="vertical">

<TextView
android:id="@+id/resultView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="40sp"
android:layout_marginTop="80sp"/>

</LinearLayout>

 

 

AS中級 値の受け渡し編①問題~Activityから別のActivityへ値を渡す~

Try1. MainActivityで、デフォルトで、『x + y  =?』と表示。

   x=______  y=______  の欄に値を入れると、

例えば、x= 5 y= 6 と入れて、『代入』ボタンを押すと、

『x + y  =?』⇒『5+6=?』と表示が変わる。

『答えは次ページ』ボタンを押すと、次のSecondActivityへ遷移して、『11』が中央にどんと表示されている。

このようなアプリを作ります。

 

Try2.上記と同じように、今度は文字列を連結して、その結果をSecondActivityへ遷移して、結果を表示します。

ちょっと考えてみた43

TYPE_STEP_COUNTERを使用して、歩数計を作成しようとしたがうまくいかず、

Develpersをみると、API29以上だと、何らかのpermissionの記載が必要とのことであった。

AndroidManifest.xmlに下記記載するだけで乗り切れるのか試行中です。

<permission android:name="ACTIVITY_RECOGNITION"/>

 

Android studio のTYPE_STEP_COUNTERを実装したい (teratail.com)

ちょっと考えてみた42

DialogFragmentから、呼び出し元のActivityに値を返したいのだが、これがかなり難解であるので手間取っています。

 

参考は下記でよいと思ってます。

FragmentからActivityへの値の受け渡し (teratail.com)

次のはKotlinで書いてますが、目的のものです。

【Kotlin】DialogFragmentからActivityへ値を渡す - Qiita

このKotlinを読み解くのが最もはやいような気がするので、これを機にKotlinを読めるようにしたいと思います。

 

akira-watson.com

 

 

AS Room編③解説part1~DatePicker/TimePickerの使用および、時間順に並べ替え、ExecutorSerVice使用~

DatePickerを配置してみました。

 

MainActivity.java

package com.example.taskdatabasedemo1;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class MainActivity extends AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

Button calendarBtn = findViewById(R.id.calendarBtn);
calendarBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
DatePickerDialogFragment datePicker = new DatePickerDialogFragment();
datePicker.show(getSupportFragmentManager(),"DatePicker");

}
});
}
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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=".MainActivity"
android:gravity="center_horizontal"
android:orientation="vertical">

<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="When"/>

<EditText
android:id="@+id/whenEdit"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>

<Button
android:id="@+id/calendarBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="カレンダーで選択"/>

</LinearLayout>

DatePickerDialogFragment.java

package com.example.taskdatabasedemo1;

import android.app.DatePickerDialog;
import android.app.Dialog;
import android.os.Bundle;
import android.util.Log;
import android.widget.DatePicker;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.fragment.app.DialogFragment;

import java.time.LocalDate;
import java.time.format.DateTimeFormatter;

public class DatePickerDialogFragment extends DialogFragment implements DatePickerDialog.OnDateSetListener {
@NonNull
@Override
public Dialog onCreateDialog(@Nullable Bundle savedInstanceState){
LocalDate dateNow = LocalDate.now();
int year = dateNow.getYear();
int month = dateNow.getMonthValue();
int day = dateNow.getDayOfMonth();

Dialog datePickerDialog = new DatePickerDialog(getActivity(),this,year,month,day);
return datePickerDialog;
}

@Override
public void onDateSet(DatePicker datePicker, int year, int month, int day) {
String dateStr = datePicker.getYear()+"/"+datePicker.getMonth()+"/"+datePicker.getDayOfMonth();
Log.v("MY_LOG",dateStr);

}
}