我が家のコーヒー事情
自分がコーヒーをハンドドリップで淹れ始めたきっかけは一昨年から始めたコーヒーダイエットです。
朝食にバターを入れたコーヒを飲むことに最初はすごい抵抗感がありましたが、今では完全に習慣化されて朝食にご飯を食べることに違和感があるくらいです(笑)
なぜ続けられたか考えてみると、どうせ飲むならより美味しいコーヒーを飲みたいと思って試行錯誤するのが楽しかったからだと思います。
今回は、そんな試行錯誤の状況を時系列とコーヒー豆・ドリッパー・ミルの3要素で振り返ってみたいと思います。
2015年11月頃
コーヒー豆
カルディコーヒー・近所の個人経営してる珈琲屋さんから購入
ドリッパー
カリタ製コーヒードリッパー
ミル
なし
コーヒーダイエットを始めた時期ですね。
まずは最低限の道具で始めようと思ってドリッパーだけ買いました。
豆は近所にカルディがあったので基本的にはそこで買うようにして、たまにスペシャリティコーヒーを売っているお店で買ったりしてました。
スペシャリティコーヒーは美味しく感じますが継続的に飲むにはちょっと高すぎました。。。
2016年
コーヒー豆
ドリッパー
カリタ製コーヒードリッパー
ミル
カリタ製セラミックミル
この年はまず、コーヒーミルを買いました。粉の状態で買うと1週間たたないうちに酸化した豆の匂いがしたり蒸らすときに豆が膨らまなくなったりしました。豆を買ってるお店で聞いてみたら、豆は豆のまま買って飲むときに挽くといいですよ、と教えて頂きました。そこでオススメのミルを聞いた結果がこれでした。たしかに豆のまま保存したほうが持ちがよかったです。
あと、この年の一番の発見は辻本珈琲さんの豆ですね。会社内のふとした話から知ったのですが、500gで約600円とコスパがやばかったので即購入しました。スーパーで売ってる豆と同じくらいの値段なのに蒸らすとめっちゃ膨らむ!と感動しました。今では常連で1kgとか普通に買ってます。
2017年
コーヒー豆
辻本珈琲
ドリッパー
- カリタ製コーヒードリッパー
- ハリオ V60ドリッパー
ミル
カリタ製セラミックミル
今年ですね。ハリオのV60が気になってて買おうと思っていたのですがスペース的な問題で買えなかったのですが引っ越しを機に買いました。
使った感じコーヒーの抽出量をコントロールできるのがよかったです。濃いコーヒーが苦手な人には薄めで入れたりできるので。
今年はあとミルを新調したいです!今のミルだと微粉がやばいことになってて茶こしで微粉を落とすとかなりの量の微粉が取れます。豆の4分の1くらいは微粉になってそうな勢い・・・。もっといいやつ買う。
以上です。快適なコーヒーライフを
Settings.Global.getFloatでAnimationScaleが取得できない
Android 6.0.1の端末でAnimationScale(Transition, Duration)が取得できない問題に遭遇しました。
Mからパーミッション変わった影響かなーとパーミッション見直したり、Settings.Globalのソースを見ても特に問題ないような・・・
ぐぐってもアニメーションOFFにするとスマホが早くなるよ!みたいな記事ばかりでうんざりしているとCLIで端末の設定を覗けることが判明。
試して見ると
$ adb shell settings list global | grep anim $
何も表示されず・・・。設定が見えない。さらに調べてみると
AndroidフレームワークのAnimation設定まわりでバグがあったようです。
これの影響かどうかわからないですが、開発者設定でアニメーション設定を変更したところ
$ adb shell settings list global | grep anim animator_duration_scale=1.0 transition_animation_scale=1.0 window_animation_scale=1.0 $
表示されるようになりました。何かスッキリしないですがそんなことがありました。
CalendarクラスのcompareToが分かりづらい
今まで日付の比較を行うときはCalendarクラスのcompareToを使ってやってました。
でもcompareToって直感的じゃなくて毎回リファレンスみて「なるほど」となってたんですよ。
なんか良い実装ないかなぁと思ってましたが、よくよくソースを見てみるとやってることは単純でした。
public int compareTo(Calendar anotherCalendar) { if (anotherCalendar == null) { throw new NullPointerException("anotherCalendar == null"); } long timeInMillis = getTimeInMillis(); long anotherTimeInMillis = anotherCalendar.getTimeInMillis(); if (timeInMillis > anotherTimeInMillis) { return 1; } if (timeInMillis == anotherTimeInMillis) { return 0; } return -1; }
要はUnix時間を比較してるだけなんですね。
これなら2つのCalendarで
if (calendar1.getTime() < calendar2.getTime()){ //処理 }
としたほうが直感的だと思ったので最近はこちらを使うようにしています。
アニメーション設定を見てアプリの挙動を変えたいとき
アプリに凝った実装を入れるのは大事だなーと思ってアニメーションを加えてみました。
しかし、アプリリリース後に早速問い合わせが、、、
加えたアニメーションはゆっくり縦揺れするアニメーションでしたがユーザの問い合わせによるとアニメーション対象物がブルブル震えてるとのこと(((( ;゚Д゚)))ガクガクブルブル
調査したところ開発者オプションのアニメーション間隔設定がオフされていると再現しました。
そんなときは
canUseDuration = Settings.Global.getFloat(contentResolver, Settings.Global.ANIMATOR_DURATION_SCALE, 0);
APIレベル17未満の場合は
canUseDuration = Settings.System.getFloat(contentResolver, Settings.System.ANIMATOR_DURATION_SCALE, 0);
のように書くと設定値が取得できます。オフの場合は0が返ってくるのでその場合はアニメーションしないようにしました。
完全無欠ダイエットやってみた。
社会人になってからだんだんとメタボ体質になっており何とかしなくてはと思いつつも食事は改善せずにマラソンや水泳をやってる日々でしたが、年末年始あたりに読んだ下記の本が面白くて試したくなるレベルでした。
- 作者: デイヴ・アスプリー,栗原百代
- 出版社/メーカー: ダイヤモンド社
- 発売日: 2015/09/18
- メディア: 単行本(ソフトカバー)
- この商品を含むブログ (13件) を見る
内容はコーヒーにグラスフェッドバターという牧草だけ食べて育った牛のバターを大さじ1〜2杯とMCTオイルという中鎖脂肪酸という体に良い油を大さじ1〜2杯入れて飲むというもの。
当時はコーヒーのハンドドリップにはまってて自動コーヒーミルを買おうと思ってた矢先だったのでその辺のことも完全無欠ダイエットを始める後押しになった。
スペシャリティコーヒーが良いということだったので、近所のコーヒー専門店でいい豆を買いました。バターはamazonで海外から取り寄せました。
初めて〜1ヶ月
いきなりバターや油を通常量入れると体調をくずす人もいるらしかったので、初日はスペシャリティコーヒーを挽いて抽出し、そこにバターを最初は大さじ1/2くらいいれてオイルは数滴とかかなり慎重に始めました。
そのおかげが体調をくずすこともなく良い感じのスタートがきれました。ただ、バターとオイルの量が少なすぎると昼ご飯までに腹が減るので自分で調整して昼ご飯まで空腹にならない量を模索する必要があります。
1ヶ月〜2ヶ月
最初2週間ぐらいは変化がなかったんですが、3〜4週間頃から背中まわりに着いた脂肪が落ちてる感じがしてきました。
また、1ヶ月経つぐらいからは腹まわりの脂肪が減ってきてベルトの穴1つ分ウェストが痩せました。
ほんとに効果あるのかすごいなーと思いました。朝食に炭水化物のかわりに油を摂るようにするだけでこんなに違うのかと。
ちなみに変えたのは朝食のみで昼ご飯と晩ご飯は今まで通りふつうにとってます。
なので調子にのって晩ご飯の後にデザートとか食べてると痩せないところか太ります。
「朝食でダイエット頑張ってるから晩ご飯にデザート食べるかー」みたいな残念な考え方をなくしていきたい。
2ヶ月〜
2ヶ月ぐらい続ける間にいろいろ試した結果、以下のことがわかりました。
・コーヒーはスペシャリティコーヒーじゃなくてプレミアムコーヒーでもいける(飲んだ感じ差が感じられない)
・グラスフェッドバターは必須(同じくこのダイエットを試していた知り合い曰く、普通のバターで試したら胃もたれしたとのこと・・・)
・MCTオイルは味がほとんどしないので何にでも合う
長期的にダイエットをするときに一番ネックになるのがコストですよね。
ダイエットに使う食品でダウングレードできるものがないか模索してみたんですが、バターとオイルをケチるといけないことがわかりました。また、コーヒーはプレミアムでもそこまで変わらないのでは?ということでカルディで買った豆を使用しています。
コーヒーを安くできましたが、他を何とかしたいなーと思い色々探しているとグラスフェッドバターが5kgで買えることがわかりました。
かなりの量だと思いますが、200gで買うものよりも3倍安かったので迷わず買いました。
でかいです。冷凍庫の1/3が占領されました。
ですがこれで完全無欠ダイエットを長期継続できそうです。
1年ぐらい続けたらどれくらいかわるのかなーとワクワクしてますが、調子にのって食べ過ぎる癖をやめないとあんまり変わらないかも・・・
次回は体重測っておいてグラフにできたらいいな。
CentoOSにJDKが入れらないとき
wget http://download.oracle.com/otn-pub/java/jdk/8u73-b02/jdk-8u73-linux-x64.rpm
参考サイトによくあるように上記のようなコマンドを打つとダウンロードに失敗します。
--2016-03-18 08:57:30-- http://download.oracle.com/otn-pub/java/jdk/8u73-b02/jdk-8u73-linux-x64.rpm Resolving download.oracle.com... 165.254.42.40, 165.254.42.51 Connecting to download.oracle.com|165.254.42.40|:80... connected. HTTP request sent, awaiting response... 302 Moved Temporarily Location: https://edelivery.oracle.com/otn-pub/java/jdk/8u73-b02/jdk-8u73-linux-x64.rpm [following] --2016-03-18 08:57:30-- https://edelivery.oracle.com/otn-pub/java/jdk/8u73-b02/jdk-8u73-linux-x64.rpm Resolving edelivery.oracle.com... 23.218.8.217 Connecting to edelivery.oracle.com|23.218.8.217|:443... connected. HTTP request sent, awaiting response... 302 Moved Temporarily Location: http://download.oracle.com/errors/download-fail-1505220.html [following] --2016-03-18 08:57:31-- http://download.oracle.com/errors/download-fail-1505220.html Connecting to download.oracle.com|165.254.42.40|:80... connected. HTTP request sent, awaiting response... 200 OK Length: 5307 (5.2K) [text/html]
こんな感じです。
いろいろ調べてたら答えが書いてあるサイトがありました。
正解は
wget --no-cookies --no-check-certificate --header "Cookie: oraclelicense=accept-securebackup-cookie" http://download.oracle.com/otn-pub/java/jdk/8u73-b02/jdk-8u73-linux-x64.rpm
たしかにブラウザではAcceptのラジとボタン選択するけどCUIでダウンロードするときは必要ないのかなとか思ってたけど、そんなことありませんでしたorz
おそらくまたハマると思われるのでメモ。
TDDBCに行ってきた
久しぶりの更新になります。
本日、TDDBC in Tokyo 2016-02 - TDDBC | Doorkeeperに参加させて頂きました。
TDD自体は興味があって趣味の範囲でちょこちょこJUnit触ったりとか最近だとEspresso触ったりしていたんですが、
業務ではまったくやっていないため入門書をかじった程度で止まっていました。
そこから先に進んでみたいなと思い今回参加に踏み切りました。
午前の部(導入)
午前中は@setoazusaさんによるTDDとはなんぞや?という解説(基調講演)を聞きました。
TDDの知識はネットと本でしか得ておらず、実践している方からお話が聞けたのはとてもためになりました。
特に自分に刺さったのは
- 不安をテストで表現する
- TDDをやれば偉いわけじゃない
- なぜTDDするのか
です。特になぜTDDするのか?は考えさせられました。一番最初に興味を持ったのは当時担当していたAndroidアプリのリリース頻度が短くて毎回人力テストをしていたときに辛みが増してきて、リリース前のテストを自動化できたらいいのにとか思ってたときですね。最近では、Espressoかっけー!テストやってる感じがする!テスト書いてる自分偉い!ってなってました。開発効率全然考えてない・・・。プログラマの三大美徳がおざなりになってました。
その後は、運営チームの方がペアプロのデモをしてくれました。
デモを見ながら、あーこんなペースで話しながら開発するなんて無理だわって思ってました。
手慣れてる感がすごい。
午後の部(ペアプロでTDD)
午後は実際にペアプロしてみましょうということで早速ペア決めを。自分はJavaを選択しました。ここでKotlinとか言えたらかっこよかったのかな。
その後、お題が出されそのお題をTDDしながら2人で開発していくことに。ペアプロ自体もあまりやったことがなかったので新鮮でした。というかペアでキーボードを叩いていないときは何をすればいいかわからなかったのでとりあえず、スペルミスがないかチェックと実装に悩んでたら一緒に悩む的なことをしてました。最終的には課題4?まで終わってフィニッシュ。後半は頭の回転が鈍くなりペアの方の実装を目で追うので精一杯に・・・
ここで疑問が。ペアプロの場合、組む相手が自分の知らないライブラリやクラスを使い始めたらどうすればいいんだろう。
ペアでする以上片方がついていけなくなるとペアプロの意味がなくなるような気もする。かといって一々解説してもらってたら開発効率が下がるだろうなーと思ったり。
ためになったことは仮実装という概念です「。座標(1, 2)を与えたらgetXは1を返す」というテストをするとき、一番最初に実装するgetXの戻り値は1というハードコーディングでも良いというのは驚きでした。あるテストがあったときにそのテストを最低限の労力でグリーンにするということを念頭に置いて実装していくといいのかなと思いました。
後はレビューという時間があるのも新鮮でした。コードについて議論の経験に乏しい自分では皆の言ってることに納得しかできませんでした。もっと議論できるようになりたい。
改善点とか
終了間際に運営にフィードバックあったらお願いしますって言われましたが、TDDにより頭がパンクしていてその場ではまったく出てきませんでした。帰宅して、ブログに起こすにあたり思い当たる節があったので箇条書きでまとめます。
- デモのときにペアプロの解説が欲しかった(ドライバー・オブザーバーの役割等)
- (個人のレベルもありますが)課題が途中から急に難易度が高くなり実装を考える時間が大幅に増えたので、問題をもう少し簡単にしてもらえると実装を考える時間を減らしTDDに費やせる時間が増やせるのかなと思いました。