2019年9月8日日曜日

Flutter - SafeArea

これからのモバイル開発はFlutter一本でよいと思います。
ということで、今後はFlutterメインで。

Widget of the weekly ① SafeArea

https://www.youtube.com/watch?v=lkF0TQJO0bA&list=PLjxrf2q8roU23XGwz3Km7sQZFTdB996iG&index=2

Status bar領域やデバイスのコーナーなども考慮してアプリが安全に描画できる領域を自動的にpaddingしてくれるのがSafeArea。
AppBarを使用せず、paddingも入れずにレイアウトを組むと以下のようになってしまう。

タブがSBarの背面に潜り込んでいる。

SafeAreaを使ってみる(topのみpadding true)
  Widget build(BuildContext context) {
    return Scaffold(
      body: SafeArea(
        top: true,
        bottom: false,
        left: false,
        right: false,
        child: _createBody(context),
      ),
      backgroundColor: Colors.yellow,
    );
  }

MediaQuery.of(context).paddingを取得してContainerにpaddingを取得するのと同じ事だが、若干便利。Statelessなので積極的に使ってよい。




2017年11月12日日曜日

[Angular]Windows開発環境作成

※windows10

■node/angularインストール
1.node.jsをインストール
node -v
2.angular-cliインストール ※linuxと同様
npm install -g angular-cli
3.angularプロジェクト作成 ※linuxと同様
ng new test
4.angular実行
ng serve --open

■デバッグ
1.VS codeをインストール
2.Extensionのangular essentialsをインストール
3.作成したangularプロジェクトをOpen
4.launch.jsonを作成する
{
  "version": "0.2.0",
  "configurations": [
    {
      "type": "chrome",
      "request": "launch",
      "name": "Launch Chrome",
      "url": "http://localhost:4200",
      "webRoot": "${workspaceRoot}",
      "sourceMaps": true,
      "userDataDir": "${workspaceRoot}/.vscode/chrome",
      "runtimeArgs": [
        "--disable-session-crashed-bubble"
      ]
    },
    {
      "name": "Attach Chrome",
      "type": "chrome",
      "request": "attach",
      "url": "http://localhost:4200",
      "port": 9222,
      "webRoot": "${workspaceRoot}",
      "sourceMaps": true
    }
  ]
}
5.ng serveを実行
6.VS codeから実行

これでVSCode上でブレイクポイントも張れます

2017年10月22日日曜日

[AWS]AWS導入メモ3(angular導入)

これも公式通りにangular-cliを使用

https://github.com/angular/angular-cli

■疎通確認
nginxから4200をfowerdingしてもInvalid Host headerになる。
ホスト名チェックでエラーになっているようなので一時的に以下をtrue固定にして確認。動作確認出来たらもとに戻す。

node_modules/webpack-dev-server/lib/Server.js
・checkHostのreturnをtrue固定

■Angularのビルド
ng build
※dist/が作成される

■expressをインストール
angularで作成したフォルダに移動して以下を実行
npm install --save express

expressコマンドが作成した/bin/wwwをコピーしてAngularを表示するようにする
以下を参考
https://qiita.com/frost_star/items/75290a6749fb7933b420

bin/www

// 使用するライブラリの読み込み
const express = require('express');
const path = require('path');
const http = require('http');

// api.js(サーバサイドの処理スクリプト)の読み込み
const api = require('./server/routes/api');

// expressの初期化
const app = express();

// 静的ファイルパスの設定
// ビルド後のAngularのパスを設定する
app.use(express.static(path.join(__dirname, 'dist')));

// /apiでアクセスしたときはapi.jsを表示
app.use('/api', api);

// 任意のURLでアクセスしたときはdist/index.html(Angularのindex.html)を表示
app.get('*', (req, res) => {
  res.sendFile(path.join(__dirname, 'dist/index.html'));
});

/**
 * ポート設定
 */
const port = process.env.PORT || '3000';
app.set('port', port);

/**
 * HTTPサーバの作成
 */
const server = http.createServer(app);

/**
 * ポート監視を開始する
 */
server.listen(port, () => console.log(`API running on localhost:${port}`));

server/routes/api.js

const express = require('express');
const router = express.Router();

router.get('/', (req, res) => {
  res.header('Content-Type', 'text/plain;charset=utf-8');
  res.send('これはサーバサイドスクリプトだよ');
});

module.exports = router;

■実行
forever start ./meanapp/bin/www

[AWS]AWS導入メモ2(mongo-db導入)

公式サイト通り
https://docs.mongodb.com/ecosystem/platforms/amazon-ec2/


※現時点の手順
echo "[mongodb-org-3.4]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/amazon/2013.03/mongodb-org/3.4/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-3.4.asc" |
  sudo tee -a /etc/yum.repos.d/mongodb-org-3.4.repo
sudo yum -y update && sudo yum install -y mongodb-org-server \
    mongodb-org-shell mongodb-org-tools

2017年10月9日月曜日

[AWS]AWS導入メモ

Androidと全く関係ないですが・・・

1.AWSアカウントの作成
※以下AWSマネージメントコンソール
2.リージョンを選択(東京)
3.VPC作成
  • パブリックサブネットの作成
  • インターネットゲートウェイの作成(VPCにアタッチする)
  • ルートテーブルの作成(0.0.0.0/0をインターネットゲートウェイに設定)
  • Elastic IP(固定IP)の設定 ※インスタンスに関連付けを忘れたりインスタンスを停止したりすると課金が発生する・・・
3.EC2インスタンス作成
  • Amazon Linux AMIを選択
  • t2.microを選択(無料枠)
  • ssh用サーバ証明書をダウンロード
※以下Terminal(rlogin)
4.nginxをインストール
  • sudo yum update
  • sudo yum install nginx
  • sudo service nginx start
  • sudo chkconfig nginx on
※再びAWSマネージメントコンソール
5.セキュリティグループでインバウンド80ポートの開放
6.VPCを選択してDNS名前解決の編集を実行

※node/express
7.nvmとnodeをインストール
 https://github.com/creationix/nvm/
8.expressをインストール・実行
  $ npm install express-generator -g
  $ express myapp
  $ cd myapp && npm install
9.foreverをインストール・実行/停止
  $ npm install forever -g
  $ forever start ./myapp/bin/www
  $ forever stop ./myapp/bin/www

※app.jsの説明
  https://qiita.com/mito_log/items/735f7079f99ec78ea7e6#routerget%E3%81%A8%E3%81%AF

10.nginxからexpressへフォワーディング
  $ sudo vi /etc/nginx/nginx.conf
  ※serverブロックに以下を追加
    upstream node-backend {
          server localhost:3000;
      }
     
      location / {
           if ( -f $request_filename ) {
                break;
           }

           if ( !-f $request_filename ) {
                proxy_pass http://node-backend;
                break;
           }     
      }

2016年10月10日月曜日

[iOS]windowsを用いた開発環境構築

[準備するもの]
  • VMWare Player
  • macOS ISO or VMWareイメージファイル
  • unlocker (VMWare PlayerでmacOSを使用できようにする)

[インストール方法]
smc.version = "0"

[キーボード設定]
①vmxファイルに以下を追加し再起動する。
 keyboard.vusb.enable = "TRUE"
 keyboard.vusb.idVendor = "0x0000"
 keyboard.vusb.idProduct = "0x0000"


②キーボード設定アシスタントでJISキーボードを選択

③System環境設定->キーボードで「キーボードの種類を変更」で②と同様の操作を行う


※VMでの使用が認められているのはOS X 10.7 Lion以降です

2016年9月19日月曜日

独自で2Dアニメーションを実装するベストプラクティス

2Dアニメーションを行いたい!

といった場合、Androidにはいくつもの方法が存在します。

  • Animationクラスを使用
  • ObjectAnimatorクラスを使用
  • ViewPropertyAnimatorクラスを使用
  • SurfaceViewクラスを使用


AnimationクラスはAPI Level1からあるレガシーなAPIですが、jniのオーバヘッドが大きく、またAnimationSetで複数のアニメーションを同時実行しようした場合、それぞれが独立して動作するためパフォーマンスが良くありません。Googleはこれを早くdeprecatedにするべきです。

SurfaceViewはViewのレンダリングがHWアクセラレーションに対応してからその存在意義がなくなりました。これもdeprecatedになるべきです。

結果的に今使うべきはObjectAnimatorかViewPropertyAnimatorに絞られるわけですが、標準のAnimatorだけではどうしても実現できない複雑な動きをさせたい場合があります。

そこで使用できるのが以下のAPI。日本語に訳すと振り付け師。

android.view.Choreographer

VSync周期でコールバックしてくれるので、それを受けて自らViewのpropertyを操作すれば好きなようにアニメーションが実装できます。


----------
最後に確認したOSバージョンはAndroid 7.0です

AndroidはGoogle Inc.の商標または登録商標です