2017年09月09日


assets フォルダのファイルをコピー

HttpAccess の streamCopy でコピーそのものは簡単にできます。ただ、キャラクタセットの変換は、読み込みに対して書き込みは .write と .flash で行えるのでメソッドを作成していません。よって、以下のように OutputStreamWriter を使用します。

▼ HttpAccess パッケージのダウンロード


( 解凍して、main\java フォルダの中に コピーして下さい )
※ OkHttp より 最新の Gradle の記述を取得して build.gradle の dependencies の最後に貼り付けて下さい
例) compile 'com.squareup.okhttp3:okhttp:3.8.1'

import android.content.res.AssetManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Toast;

import com.example.lightbox.web.HttpAccess;

import java.io.InputStream;
import java.io.OutputStream;
import java.io.OutputStreamWriter;

public class MainActivity extends AppCompatActivity {

	private AssetManager assetManager;

	private InputStream inputStream;
	private OutputStream outputStream;
	private OutputStreamWriter writer;
	private String text;

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

		assetManager = MainActivity.this.getResources().getAssets();

		// ボタンをクリック
		MainActivity.this.findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {
			@Override
			public void onClick(View view) {

				try {
					inputStream = assetManager.open("sample.jpg");
					outputStream = MainActivity.this.openFileOutput("sample_copy.jpg",MODE_PRIVATE);
					HttpAccess.streamCopy(inputStream,outputStream);

					inputStream = assetManager.open("syain.csv");
					text = HttpAccess.readTextAll(inputStream,"MS932");

					outputStream =  MainActivity.this.openFileOutput("syain_copy.csv",MODE_PRIVATE);
					writer = new OutputStreamWriter(outputStream,"UTF8");
					writer.write(text);
					writer.flush();
					outputStream.close();

				} catch (Exception e) {
					e.printStackTrace();
				}

				Toast.makeText(MainActivity.this,"処理が終了しました",Toast.LENGTH_SHORT).show();

			}
		});
	}

}


画面
<?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"
              android:orientation="vertical"
              tools:context=".MainActivity">

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

</LinearLayout>

Java : サポートされているエンコーディング



posted by at 2017-09-09 18:05 | Comment(0) | テンプレート | このブログの読者になる | 更新情報をチェックする

assets フォルダの shift_jis のテキストファイルを表示

Java で テキストファイルの読み込みや、ファイルのコピーは結構面倒なので、okio を使った static メソッドを実装した HttpAccess クラスを使用しています。

▼ HttpAccess パッケージのダウンロード


( 解凍して、main\java フォルダの中に コピーして下さい )
※ OkHttp より 最新の Gradle の記述を取得して build.gradle の dependencies の最後に貼り付けて下さい
例) compile 'com.squareup.okhttp3:okhttp:3.8.1'

import android.content.res.AssetManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;

import com.example.lightbox.web.HttpAccess;

import java.io.InputStream;

public class MainActivity extends AppCompatActivity {

	private AssetManager assetManager;

	private InputStream inputStream;
	private String text;

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

		assetManager = MainActivity.this.getResources().getAssets();

		// ボタンをクリック
		MainActivity.this.findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {
			@Override
			public void onClick(View view) {

				try {
					inputStream = assetManager.open("syain.csv");
					text = HttpAccess.readTextAll(inputStream,"MS932");

				} catch (Exception e) {
					e.printStackTrace();
				}

				if ( text != null ) {
					Log.i("lightbox", text);
				}

			}
		});
	}

}


画面
<?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"
              android:orientation="vertical"
              tools:context=".MainActivity">

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

</LinearLayout>




posted by at 2017-09-09 17:36 | Comment(0) | テンプレート | このブログの読者になる | 更新情報をチェックする

インターネットのファイルをダウンロード

以下のサンプルは画像ファイルを使用していますが、表示は行ってないので一般のファイルを使用する事を想定しています。

streamCopy というメソッドを作成して、ストリームを使った汎用的なものにしています。この内部では、okio を使用しているので、上位の okhttp の 記述を build.gradle に追加しています
import android.os.AsyncTask;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Toast;

import java.io.InputStream;
import java.io.OutputStream;
import java.net.URL;

import okio.BufferedSink;
import okio.Okio;
import okio.Source;

public class MainActivity extends AppCompatActivity {

	private String image_url;
	private URL url;
	private InputStream inputStream;
	private OutputStream outputStream;

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

		image_url = "https://lightbox.sakura.ne.jp/demo/image/sample.jpg";

		// ボタンをクリック
		MainActivity.this.findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {
			@Override
			public void onClick(View view) {


				new AsyncTask<String,Void,Boolean>() {
					@Override
					protected Boolean doInBackground(String... strings) {

						Boolean error = false;

						try {
							// インターネット上の画像を取得して、Bitmap に変換
							url = new URL(strings[0]);
							inputStream = (InputStream) url.getContent();
							outputStream = MainActivity.this.openFileOutput("sample.jpg", MODE_PRIVATE);
							streamCopy(inputStream,outputStream);

						} catch (Exception e) {
							e.printStackTrace();
							error = true;
						}

						return error;
					}

					@Override
					protected void onPostExecute(Boolean error) {

						if ( !error ) {
							Toast.makeText(MainActivity.this, "画像を保存しました", Toast.LENGTH_SHORT).show();
						}

					}
				}.execute(image_url);

			}
		});
	}

	// *************************
	// ファイルコピー
	// *************************
	private void streamCopy(InputStream inputStream, OutputStream outputStream) throws Exception {

		Source source = Okio.source(inputStream);
		BufferedSink bufferedSink = Okio.buffer(Okio.sink(outputStream));
		bufferedSink.writeAll(source);

		bufferedSink.close();
		source.close();

	}

}


画面
<?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"
              android:orientation="vertical"
              tools:context=".MainActivity">

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

</LinearLayout>

※ 要 android.permission.INTERNET


posted by at 2017-09-09 16:30 | Comment(0) | テンプレート | このブログの読者になる | 更新情報をチェックする
Seesaa の各ページの表示について
Seesaa の 記事がたまに全く表示されない場合があります。その場合は、設定> 詳細設定> ブログ設定 で 最新の情報に更新の『実行ボタン』で記事やアーカイブが最新にビルドされます。

Seesaa のページで、アーカイブとタグページは要注意です。タグページはコンテンツが全く無い状態になりますし、アーカイブページも歯抜けページはコンテンツが存在しないのにページが表示されてしまいます。

また、カテゴリページもそういう意味では完全ではありません。『カテゴリID-番号』というフォーマットで表示されるページですが、実際存在するより大きな番号でも表示されてしまいます。

※ インデックスページのみ、実際の記事数を超えたページを指定しても最後のページが表示されるようです

対処としては、このようなヘルプ的な情報を固定でページの最後に表示するようにするといいでしょう。具体的には、メインの記事コンテンツの下に『自由形式』を追加し、アーカイブとカテゴリページでのみ表示するように設定し、コンテンツを用意するといいと思います。


※ エキスパートモードで表示しています

アーカイブとカテゴリページはこのように簡単に設定できますが、タグページは HTML 設定を直接変更して、以下の『タグページでのみ表示される内容』の記述方法で設定する必要があります

<% if:page_name eq 'archive' -%>
アーカイブページでのみ表示される内容
<% /if %>

<% if:page_name eq 'category' -%>
カテゴリページでのみ表示される内容
<% /if %>

<% if:page_name eq 'tag' -%>
タグページでのみ表示される内容
<% /if %>
この記述は、以下の場所で使用します