androidで画面遷移をつくる

まず、activity_main.xml
linearlayouにbuttonを配置する

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity">

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button"
        android:id="@+id/button"></Button>

</LinearLayout>

New -> Activity -> Empty を選択する

ActivityNameを決める。ここでは、SubActivity

すると、res->layoutにactivity_sum.xmlができ、java->jp->hogeにSubActivity.javaが出来ている。

activity_sub.xml

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.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=".SubActivity">


    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="サンプルの遷移先です"
        android:id="@+id/textView"
        />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="サンプルの遷移先です"
        android:id="@+id/textView"
        />

</android.support.constraint.ConstraintLayout>

MainActivity.java

this, SubActivity.class
Intent classでは遷移元と遷移先を実装している。

package jp.hoge.listview;

import android.content.Context;
import android.content.Intent;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;

import java.util.ArrayList;

import jp.hoge.anew.SubActivity;

public class MainActivity extends AppCompatActivity
 implements View.OnClickListener{

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

        findViewById(R.id.button).setOnClickListener(this);
    }
    public void onClick(View view){
        Intent intent  = new Intent(this, SubActivity.class);
        startActivity(intent);
    }
}

buttonを押すと、activity_sub.xmlに遷移するようになりました。なるほど!

フィルムカメラを現像して、QRコードでスマホに転送する

EOS630で撮影した写真をPALETTE PLAZAさんでフィルムから現像して、QRコードでiosに転送しダウンロード

現像24枚で700円、スマホ転送サービス500円、現像の所要時間1時間

やっぱり現像はめんどくさい&スマホ転送サービスを使うと画質が落ちるらしい
->どう考えてもデジカメの方がいい
->iphoneのカメラで撮れば、現像なんて面倒なことしなくていい

といいつつ、またフィルムを買ってしまった。
ああああああああああああああああ、、、、、駄目だこりゃ。

で、思ったこと。
1.みんないいカメラを使っている。
2.カメラの撮り方も色々あるっぽい。(素人目では、どういう撮り方がいいのか良くわからない)
3.カメラも大事だが被写体も大事。
4.一眼レフカメラをやってる人は年齢層が高い。
5.あまりやりすぎても本末転倒(プログラミングに時間をかけるべき)だが、カメラもまあまあ面白い

で、一番知りたかったことだが、
6.いいカメラマンの見分け方 ->まだ全然わからないが、経験ある人・カメラに情熱がある人の方が知識が豊富で勉強になりそうだ
これは、今後productをつくっていく上で大事かも。。

ic_launcher_roundを使う

int[] icons = {
                R.mipmap.ic_launcher_round,
                R.mipmap.ic_launcher,
                R.mipmap.ic_launcher,
        };

丸いアイコンになりました。
R.mipmapは、resのmipmapの中、という意味でしょうかね。

では、res->drawableにlogo.pngを置いて、R.drawable.logoと書きます。

int[] icons = {
                R.drawable.logo,
                R.mipmap.ic_launcher,
                R.mipmap.ic_launcher,
        };

あら、サイズがおかしなことになってますが、R.drawable.logoで表示はされているようです。
logo.pngがphotoshop書き起こしのサイズですね。。

setOnItemClickListener

setOnItemClickListenerでタップした時の処理

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

        ListView myListView = (ListView) findViewById(R.id.myListView);

        ArrayList<User> users = new ArrayList<>();
        int[] icons = {
                R.mipmap.ic_launcher,
                R.mipmap.ic_launcher,
                R.mipmap.ic_launcher,
        };
        String[] names = {
                "yoshida",
                "kobayashi",
                "igawa"
        };

        String[] locs = {
                "Hamamatsucho",
                "Marunouchi",
                "Ebisu"
        };

        for(int i = 0; i < icons.length; i++){
            User user = new User();
            user.setIcon(BitmapFactory.decodeResource(
                    getResources(),
                    icons&#91;i&#93;
            ));
            user.setName(names&#91;i&#93;);
            user.setLoc(locs&#91;i&#93;);
            users.add(user);
        }
        UserAdapter adapter = new UserAdapter(this, 0, users);
        myListView.setAdapter(adapter);
        myListView.setOnItemClickListener(new AdapterView.OnItemClickListener(){
           @Override
           public void onItemClick(
                   AdapterView<?> adapterView,
                   View view,
                   int i,
                   long l
           ) {
                TextView name = (TextView) view.findViewById(R.id.name);
                Toast.makeText(
                        MainActivity.this,
                        Integer.toString(i) + ":" + name.getText().toString(),
                        Toast.LENGTH_SHORT
                ).show();
                name.setText("Tapped");
           }
        });

    }

こりゃ覚えること多すぎて、思ってたより時間かかりそーだ

classを使ったArrayList

かなり複雑

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

        ListView myListView = (ListView) findViewById(R.id.myListView);

        ArrayList<User> users = new ArrayList<>();
        int[] icons = {
                R.mipmap.ic_launcher,
                R.mipmap.ic_launcher,
                R.mipmap.ic_launcher,
        };
        String[] names = {
                "yoshida",
                "kobayashi",
                "igawa"
        };

        String[] locs = {
                "Hamamatsucho",
                "Marunouchi",
                "Ebisu"
        };

        for(int i = 0; i < icons.length; i++){
            User user = new User();
            user.setIcon(BitmapFactory.decodeResource(
                    getResources(),
                    icons&#91;i&#93;
            ));
            user.setName(names&#91;i&#93;);
            user.setLoc(locs&#91;i&#93;);
            users.add(user);
        }
        UserAdapter adapter = new UserAdapter(this, 0, users);
        myListView.setAdapter(adapter);

    }
    public class UserAdapter extends ArrayAdapter<User>{

        private LayoutInflater layoutInflater;
        public UserAdapter(Context c, int id, ArrayList<User> users){
            super(c, id, users);
            this.layoutInflater = (LayoutInflater) c.getSystemService(
                    Context.LAYOUT_INFLATER_SERVICE
            );
        }
        @Override
        public View getView(int pos, View convertView, ViewGroup parent){
            if (convertView == null){
                convertView = layoutInflater.inflate(
                        R.layout.list_item,
                        parent,
                        false
                );
            }
            User user = (User) getItem(pos);

            ((ImageView) convertView.findViewById(R.id.icon))
                    .setImageBitmap(user.getIcon());
            ((TextView) convertView.findViewById(R.id.name))
                    .setText(user.getName());
            ((TextView) convertView.findViewById(R.id.loc))
                    .setText(user.getLoc());

            return convertView;
        }
    }
    public class User {
        private Bitmap icon;
        private String name;
        private String loc;

        public Bitmap getIcon() {
            return icon;
        }

        public void setIcon(Bitmap icon) {
            this.icon = icon;
        }

        public String getName() {
            return name;
        }

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

        public String getLoc() {
            return loc;
        }

        public void setLoc(String loc) {
            this.loc = loc;
        }
    }

LinearLayoutのリストをつくろう

linearlayoutを入れ子にします。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
          android:padding="16dp"
        android:orientation="horizontal"
          android:layout_width="match_parent"
          android:layout_height="wrap_content">

    <ImageView
        android:id="@+id/icon"
        android:src="@mipmap/ic_launcher"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        />

    <LinearLayout
        android:layout_weight="1"
        android:orientation="vertical"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        >

        <TextView
            android:id="@+id/name"
            android:text="yamada"
            android:textSize="24sp"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            />
        <TextView
            android:id="@+id/loc"
            android:text="tokyo"
            android:textSize="16sp"
            android:textColor="#999999"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            />

    </LinearLayout>

</LinearLayout>

azure Web.configで301リダイレクトさせてRSSを取得

Web.configのファイルをつくります。

<?xml version="1.0" encoding="utf-8"?>
<configuration>
    <system.webServer>
        <rewrite>
            <rules>
                <rule name="boj-zh.azurewebsites.net" stopProcessing="true">
                    <match url="(.*)" />
                    <conditions>
                        <add input="{HTTP_HOST}" pattern="^boj-zh\.azurewebsites\.net$" />
                    </conditions>
                    <action type="Redirect" url="http://hpscript.com/rss/rss.xml" redirectType="Permanent" />
                </rule>
            </rules>
        </rewrite>
    </system.webServer>
</configuration>

boj-zh.azurewebsites.net のwebrootのディレクトリにconfigファイルを置きます。

boj-zh.azurewebsites.netにアクセスすると、http://hpscript.com/rss/rss.xmlにリダイレクトされるようになりました。
では、vagrantから、azureにアクセスして、rssが取得できるか確認してみましょう。
vagrantからazureのアドレスを読みに行きます。

require_once 'vendor/dg/rss-php/src/Feed.php';
$rss = Feed::loadRss('https://boj-zh.azurewebsites.net');

foreach($rss->item as $item){
	echo $item->title ."<br>";
}

問題なくリダイレクトして取れてます。なるほど!

icon付きのListViewを表示する

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
          android:padding="16dp"
        android:orientation="horizontal"
          android:layout_width="match_parent"
          android:layout_height="wrap_content">

    <ImageView
        android:id="@+id/icon"
        android:src="@mipmap/ic_launcher"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        />

</LinearLayout>

ArrayListへの配列の追加

javaでarraylistに配列に追加していく。

ArrayList<String> items = new ArrayList<>();
          items.add("マネックスグループ");
          items.add("オウケイウェブ");
          items.add("アカツキ");
          items.add("ジーエヌアイグループ");
          items.add("そーせいグループ");
          items.add("KLab");
          items.add("ブライトパスバイオ");
          items.add("リミックスポイント");
          items.add("ラクオリア創薬");
          items.add("楽天");

rss-phpでも、301リダイレクトのフィードからRSSを取得できるか?

composerでrss-phpを入れます。

[vagrant@localhost app]$ curl -sS https://getcomposer.org/installer | php
All settings correct for using Composer
Downloading...

Composer (version 1.6.5) successfully installed to: /home/vagrant/app/composer.phar
Use it: php composer.phar

[vagrant@localhost app]$ php composer.phar require dg/rss-php
Using version ^1.2 for dg/rss-php
./composer.json has been created
Loading composer repositories with package information
Updating dependencies (including require-dev)
Package operations: 1 install, 0 updates, 0 removals
  - Installing dg/rss-php (v1.2): Loading from cache
Writing lock file
Generating autoload files
[vagrant@localhost app]$ ls
composer.json  composer.lock  composer.phar  index.php  vendor

rss-phpでfetchします。

require_once 'vendor/dg/rss-php/src/Feed.php';
$rss = Feed::loadRss('http://hpscript.com/rss/rss.xml');

foreach($rss->item as $item){
	echo $item->title ."<br>";
}

301リダイレクトを設定しているURLをfetchします。

require_once 'vendor/dg/rss-php/src/Feed.php';
$rss = Feed::loadRss('http://phone-search.online/test/index.php');

foreach($rss->item as $item){
	echo $item->title ."<br>";
}

OK つまり、301リダイレクトで、フィードのURLが変わっても、旧URLに301リダイレクトをかけている間は、新URLのフィードを取得できる。