2010年12月30日木曜日

脳を「見える化」する思考ノート

脳を「見える化」する思考ノート
午堂 登紀雄
ビジネス社
売り上げランキング: 131940

~B5ノート一冊に、仕事もプライベートもすべての情報を書き込む~

メモ本ブームの昨今ですが、こちらの本は他のメモ本とは基本コンセプトが異なっており、他のメモ本を読んできた方々にも一読の価値があるかと思います。

この本で提案しているメモの方法の最大の特徴は時系列でメモを書かないということです。

本書で紹介されている方法は、1ページごとにテーマを書き込んでいき、新しいアイディアを思いついたら随時ページに書き足していくという方法です。

日頃メモを時系列に沿って記録しているんだけど、「何か思いついたアイディアが他のメモと一緒に時の流れに埋もれてしまう」という方は、この本に紹介されている方法を試してみてはいかがでしょうか。

【思考ノートの基本ルール】

2010年12月29日水曜日

はじめてのScala Swing ~SimpleGUIApplicationにはまる~

最近Scalaを学ぼうと思って、コップ本を購入しました。
とりあえず何か楽しそうなところからということで、ScalaのGUIプログラミングから始めました。
import scala.swing._

object FirstSwingApp extends SimpleGUIApplication {
 def top = new MainFrame {
  title = "First Swing App"
  contents = new Button {
   text = "Click me"
  }
 }
}

これを
C:\Study\Scala>scala FirstSwingApp.scala

として実行しようとしたら、何もおきずにプログラムが終了してしまった。
最初に何かを間違えてしまったのかと色々調べても一向に解決策が見つからない・・・。

結局
C:\Study\Scala>scalac FirstSwingApp.scala
C:\Study\Scala>scala FirstSwingApp

で無事実行することができた。
scalacでコンパイルしたプログラムはscalaコマンドで実行できるらしい。

2010年12月27日月曜日

仕事は楽しいかね?

仕事は楽しいかね?
仕事は楽しいかね?
posted with amazlet at 10.12.13
デイル ドーテン
きこ書房
売り上げランキング: 987

もし宇宙が信じられないような素晴らしいアイディアをくれるとして君はそれにふさわしいかな?

(本書より)

主人公は、足止めとなってしまった空港で一人の老人と出会います。その老人が主人公に成功するための秘訣を伝授していきます。彼は世間一般に知られている成功法を真っ向から否定し、代わりにたったひとつの原則とそれを実践するための方法を伝授します。

以上が基本的にはあらすじなんですが、老人の言葉のひとつひとつが奇妙な説得力を持っていて、読んでいてどんどひきつけられていきます。短編(小説というには長すぎる)小説としても十分楽しめる本だと思いました。

ただ本書を読んでいて、個人的に残念だなと思う点がひとつだけあるのです。

それは、本書には一貫してあるメッセージが込められていると思うのですが、それが少しオブラートに包まれすぎていて、読んでいてもイマイチ響いてこないなあという印象を持ってしまいました。

ちなみにそのメッセージとは「とにかく行動しろ!!」ということです。

まあ、あくまで私の主観ですが・・・・・。

ただ、老人が提案している原則とその実践法はとてもシンプルであり、本書を読むと「よし自分もやってやる」とモチベーションがあがること間違いなしですので、ぜひ本書を一度読んでみることをお勧めします。

【読書メモ】
アイディアを生み出す方法
リストを三つつくるんだ。
  1. 仕事上でやったミスを全部書き出すこと。

  2. 次は、問題点を書き出すこと。仕事に関してイライラすることを残らず並べるんだ。
    誰かほかの人が不平をもらしているのを聞いたことがあったら、それも書き出すこ。ヒーローになりたいなら他人の問題も解決しないとね。

  3. 最後に仕事に関してやっているすべてのことをリストアップすること。

  4. 2. 3. 1. の順番でリストに取り組む

  5. 問題点のリストを取り出し、その問題をどうすれば解決できるか「あらゆる事」を試してみる。
    • 例:アメリカのある教授は自分の息子の成績が悪いのが悩みだった。彼は成績優秀な教え子を観察することで、それまでにあまり知られていなかった成績向上の秘訣を見出した。そのノウハウをビジネスにつなげ成功した。
    • 『困難というのは、一つ一つが実地演習を始める合図だ。試すことは一つ一つが世の中への問いかけだ。答えというのは、一つ一つが旅だ。旅程の計画は人生に任せておけばいい。きみの仕事は光を集めることとカメラを持っていくことなんだから』(本書より)

  6. 仕事に関してやっていることのリストに別のアイディアを足し、新しいアイディアを生み出す。
    • アメリカの番組「六十ミニッツ」のプロデューサーは、テレビ番組に雑誌の要素を取り入れ、新しいスタイルの番組を作り上げた。
    • あらゆることを変えるには、まず<あらゆること>とは何かというリストをつくる必要がある。
    • 「きみは、仕事のひとつは報告書を書くことだと言ってたよね。そう言ったとたん、きみは研究すべき事柄を持ったことになる。報告書をペンで書かないとしたらどうなるか。重要なところをテープに録音したらどうなるか。報告書に各データについてはどうだろう。今とは違う方法を採れないだろうか。そういう報告書を、他者はどう扱っているのだろうか。(中略)ランチタイムに図書館へ行って、本や雑誌を書いている人たちがどんな風にデータを報告しているか調べてみるといい。
    • 多くの人々は自分の仕事をあまりにも狭いものに定義しすぎだ。工学技術を駆使した能力が町で一番なら自分より素晴らしいエンジニアはいないと思ってしまうんだ。だけど、優れたエンジニアであるためには、高い技術だけじゃなくいろんなものが必要だ。アイディアを売る能力もいる。みんなと一緒に働く能力も、話し合いをリードする能力も、無意味な話しあいを避ける能力も。
      ― 必要とされる能力は、それこそ何十もあるんだ。だからこそ、しなければならないことを全部、リストに書き出し続けることが重要になる。
      そして仕事を再定義し続け、リストをどんどん広げていかなければならないんだよ。-試してみることに失敗はない。

  7. 最後に仕事上でやったミスから、何か新しいアイディアを思いつけないか検討する
    • これは最後に取り組むべきリストだ。成績が<向上した>生徒のために取ってあるものだからね。ほかの二つのリストに取り組んで、それからこのリストに戻ること。それにこのリストに戻ってくるときは、感情や責任や怒りは横においておかなければならない。
      ― 過ちを見るときはね、感情を抜きにして見なくちゃいけないんだよね。
その他読書メモ
  • 「僕がいままでに掲げた目標が一つだけある。聞きたいかね?」"明日は今日と違う自分になる"だよ。
  • これは僕の大好きな言葉の一つなんだ。"遊び感覚でいろいろやって成り行きを見守る"。
  • 必要は発明の母かもしれない。だけど、偶然は発明の父なんだ。
  • 他人を凌ぐ人物になるための二つのルール
    1. "適切な時"とか"完璧な機会"なんてものはないということ。
      これは<この場で><ただちに>始めるということだ。
    2. もう一つはパッと浮かぶ考えはたいてい使い古されたものだし、パッと浮かんだわけではない考えの多くもやっぱり使い古されてものだということ。とどのつまりこういうことだ。
<一か八かの賭けをしないなら、チャンスなど一つもない>
  • 本当の達成というのは、あるべき状態より良くあることなんだ。ただ良いだけじゃなく目を見張るようなものであること。
  • もし宇宙が信じられないようなすばらしいアイディアをくれるとして君はそれにふさわしいかな?
  • 『何もするな、そうすれば素晴らしいアイディアがやってくるだろう』じゃない。
    『<あらゆること>をしろ。素晴らしいアイディアは、どこからやってくるかわからないのだから』

2010年12月22日水曜日

lambda式の引数に値を渡す方法

忘れてしまうのでメモ
(lambda (a b) (+ a b))
というlambda式があったとして、この式の a、b の引数に値を渡すには
((lambda (a b) (+ a b)) 2 3)
という形で、値をlambda式ごと括弧で括ってしまえばよい。

2010年12月14日火曜日

弱者の兵法

弱者の兵法 野村流 必勝の人材育成論・組織論
野村 克也
アスペクト
売り上げランキング: 16185

~プロフェッショナルの「プロ」とは、プロセスの「プロ」でもあるといえる。~

(本書より) あの野村監督(今は監督ではないですが、あえてこう呼ばせていただきます)が書いた人材&組織の本です。
タイトルからも想像できるように
  • 勝てる組織とは
  • プロフェッショナルとは
  • 人を育てるとは
など野村監督の監督・野球人としての哲学がギュッと詰め込まれた読み応えのある良書です(もちろん私の主観ですが)。
読んでいて感じたのですが、野村さんのプロフェッショナリズムや組織論というのは、あのサッカーのオシム氏のそれと非常に近い気がします。それだけに、是非一度この2人の対談を見てみたいですね。
それにしても、こうも哲学が似通っている2人のうち片方が日本を離れても未だにマスコミから意見を求められ、もう片方はヒールキャラになってしまっているのは何故なんですかね?スポーツの違いなのか、日本人と外国人の違いなのか、嫁がテレビに出てるのと出てないのの違いなのか・・・。
【読書メモ】
  1. 「中心なき組織は機能しない」。これは私が度々口にする組織論の大原則である。野球に限らず、中心的役割を担う人物の意識や言動は、組織内の意識や言動は、組織内のほかの人間に大きな影響を与える。
  2. 取り組み方 ― 真のプロと呼べるか否かは、そこにかかっていると私は思っている。いかにその仕事に全身全霊、全知全能をささげて取り組むことができるか。それを実践できる人間をプロフェッショナルと呼ぶのである。
  3. プロフェッショナルの「プロ」とは、プロセスの「プロ」でもあるといえる。プロセスによって、人間は成長するのである。
  4. プロにとって「満足は最大の敵」なのである。「満足」が「妥協」を生み、「これで精一杯だ」という「自己限定」につながってしまう。
  5. 「組織はリーダーの力量以上には伸びない」― これは組織論の大原則であり、長年プロ野球チームという組織に身を置いてきた私の実感である。
  6. 私は「失敗」と書いて「せいちょう(成長)」と読むことにしている。なぜなら、人は失敗することで多くを学ぶからである。失敗は成長を生み出すのだ。
  7. 自分が持っているノウハウや技術、理論を的確かつわかりやすく伝えるためには、「表現力」が必要不可欠なのだ。表現力遺憾で、選手の理解度は全く違ってくる。だからこそ、指導者は言葉を獲得しなければならない。
  8. 中国のことわざに、こういうものがある。
    財を遺すは下、仕事を遺すは中、人を遺すは上とする。
  9. 「優勝するにふさわしいチーム」とどういうものか。必ずしも選手個々の素質には恵まれていなくても、確固たるビジョンと哲学を持つ監督のもと、明確な意思統一がなされ、一丸となって戦うチームのことをいう。
  10. 「優勝するにふさわしいチーム」の条件とはなにか
    1. ひとつめは、「適材を適所に配置する」ということである。
    2. ふたつめは、「無形の力」を備えていることである。
  11. 個性は他人の納得と承認があってはじめて輝くものであり、世のため人のために役立ってこそ生きてくる個人の特性のことを指すのだと私は思っている。
  12. 無形の力とは文字どおり「かたちにならない力」、すなわち「目に見えない力」の事を指す。具体的にいえば「分析」、「観察」、「洞察」、「判断」、「決断」、「記憶」としてまとめられようか。
    ― 「分析」とはデータや情報を収集・分析し、研究することをいう。
    ― 「観察」とは、目に見えることから情報を引き出す行為だといっていい。
    ― 「洞察」は「目に見えないもの」から新たな情報を獲得する力のことを指す。その最たるものが、相手の心理を読むことである。
    ― 「判断」とはこうして得た情報をもとに、もっとも成功する確率の高い作成を選択することにほかならず、これらの行為を経た結果は、「記憶」として蓄積され、データを補足することになる。
    ― 「決断」は腹でする。
  13. 仕事を生きる糧としている以上、仕事と人生を切り離して考えることは不可能だ。仕事を通じて人間は成長し、人格が形成される。仕事を通して社会の恩恵に報いていく。それが生きることの意義である。
  14. 「進むときは上を向いて進め。暮らすときは下を向いて暮らせ」
  15. おのれの力を過信した時点で成長は止まる。
  16. 「人間は無視・賞賛・非難の段階で試される」
  17. 気づき、感じとる力がなければ、それまでなのだ。最初から教えてしまうと、この「気づき、感じ取る力」を奪ってしまうのである。
  18. もし「どうしたらいいのでしょう。どこが間違っているのでしょうか」と尋ねてくれば、そのときは絶対に突き放してはいけない。こうした機会こそ、徹底的に教え込みチャンスなのである。指導者がここですべきことは、自分で正解を見つけられるよう、自ら取り組もうとする意識を植えつけることである。そのために大切なのが「目標」を明確にさせることである。

2010年12月11日土曜日

見習いプログラマが読んだらジョブレベルがあがる10冊

先日見習いプログラマが読んだら、すぐにジョブレベルが上がる10冊 : ソースコードは飲み物です。を見て、反響が大きかったようなので自分も10冊リストアップしてみました。
自分が見習いの時期に読んで、実際にジョブレベルに直接関与したと思った本を選んでいるのでこれが誰かの役に立ってくれれば幸いです。
ちなみに、このリストは以下のような人たちをターゲットにしています。
  • 会社で研修を終えて、プログラムの基本的な組み方はなんとなくわかっている入社半年~1年ぐらいの新人。
  • Webベースのオープン系システムを開発している。

楽々ERDレッスン (CodeZine BOOKS)
(株)スターロジック 羽生 章洋
翔泳社
売り上げランキング: 110302
データベース設計の本としては、かなりいいと思っています。俗に「名著」と呼ばれるものは、変に敷居が高かったりするんだけど、この本はとにかくわかり易かった。著者の主観が随所に盛り込まれていて、抵抗を感じる人もいるかもしれないけど、そういった点も含めて自分は好きです。

改訂新版 反復学習ソフト付き SQL書き方ドリル (WEB+DB PRESS plusシリーズ)
羽生 章洋 和田 省二
技術評論社
売り上げランキング: 21236
SQLに関しては、これ1冊マスターすればまず問題ないのではないでしょうか。SQLに関しては、SQLパズル 第2版 プログラミングが変わる書き方/考え方の方を薦める人もいると思いますが、自分で実際に練習できるソフトもついているという点で、自分は断然こちらの方がお薦めです。思うに見習いプログラマでなくても、この本に書かれているテクニックを知らない人の方が圧倒的に多いのではないでしょうか?自分の会社では、この本が社内の本棚にあるにもかかわらず年上のエンジニアがここに書かれているテクニックを利用すれば簡単に解決する問題に悩んで相談してきたりするので「勉強しろよ!!」と密かに腹を立ててたりします。表向きには穏やかな表情をこころがけて丁寧に教えてたりするんですけどね。・・・・愚痴っぽくなってしまいました。

TIME HACKS!
TIME HACKS!
posted with amazlet at 10.12.10
小山 龍介
東洋経済新報社
売り上げランキング: 8909
この業界残業するのが当たり前という風潮が他の業界に比べて多いのではないかと感じています。ただ、常に新しい技術にアンテナを張り、アルゴリズムなど基本的な教養も身につける必要があるエンジニアという職種は、業務以外の時間を確保して勉強することが重要だと常々感じております。というわけで、メリハリをつけてしっかりと集中して業務に取り組む習慣を身につけるためにも、これを含めて仕事術の本は色々読んでおいたほうがいいと思います。

速習Webデザイン 改訂新版 HTML & スタイルシート
栗原 明則
技術評論社
売り上げランキング: 128289
戸惑いを感じなかったのですがHTMLは苦入社したての頃、プログラミングは大学である程度習っていたのでそんなに手でした。HTMLとスタイルシートはセットで覚えた方がいいだろうということで。この本が特別お薦めというわけではないですけど、スタイルシートのチュートリアル本を一冊やっておくのは大切だとおもいます。うちの会社のパッケージって未だにTABLEの中にTABLEを作って、表の線とかを作ってたりするので、テーブルレイアウトの本も読んでおくことを薦めたいところだけど今そういう本って全然売ってないんですよね。

AJAX Webアプリケーション アイデアブック
羽田野 太巳
秀和システム
売り上げランキング: 42245
最近本屋の店頭に並んでいるAJAX本ってJQUERYなんかのAJAXフレームワーク本が多いんですよね。JavaScriptのDOM操作関数を直接利用する方法を知っておくべきということで選出しました。他にもいい本があるのかもしれないですけど、自分はこれ1冊で満足してしまったので、他のAJAX本は読んでいないんです(笑)。Ajaxデザインパターン ―ユーザビリティと開発効率の向上のためにとかも気になってはいるんですが・・・。

WEB+DB PRESS Vol.35
WEB+DB PRESS Vol.35
posted with amazlet at 10.12.10

技術評論社
売り上げランキング: 244907
WEB+DB PRESS 総集編 [Vol.1~36]

技術評論社
売り上げランキング: 150464
テスト本(テスト駆動開発本?)って色々出てるんですけど、それらよりも得るものが多かったと感じたのがこの号の特集記事でした。この特集の補足(?)にあたる連載:[動画で解説]和田卓人の“テスト駆動開発”講座|gihyo.jp … 技術評論社の記事も一緒に読んでおくとベターです。

正規表現ポケットリファレンス (POCKET REFERENCE)
宮前 竜也
技術評論社
売り上げランキング: 191210
これも「この本がお薦め!!」というのではなく、「正規表現は大事!!」ということを言いたくて選びました。実はこの本持ってません(笑)。どんな本でもいいので、正規表現の基本が覚えたら正規表現パズルの問題を一通り自分で解いてみることをお薦めします。どっちかというとこっちのサイトがお薦め。

増補改訂版Java言語で学ぶデザインパターン入門
結城 浩
ソフトバンククリエイティブ
売り上げランキング: 6681
「犬と猫は動物」という「オブジェクト指向」は実務ではあまり役に立たないですが、デザインパターンはやっぱり大事ということで選出。この本読んで感じたのは -デザインパターンとはいかにポリフォリズムを確保するかを突き詰めた定石集 -「犬と猫は動物」が「概念としてのオブジェクト指向」だとしたら、「機能としてのオブジェクト指向」を追求しているのがデザインパターンだ ということ。2つとも同じこと言ってるような気もするけど(笑)。

StrutsによるWebアプリケーションスーパーサンプル 第3版
高安 厚思 西川 麗
ソフトバンククリエイティブ
売り上げランキング: 125818
「今更Struts?」と思う方も多々いると思いますが、元祖フレームワーク(?)だけあって、使っていてフレームワークの基本コンセプトが一番わかり易いのがStrutsではないかと思います。なんで、「一度は触ってみて」という意味も込めて選出。「XMLの設定めんどうくせ~」という部分も含めて一度は経験するべし。

オブジェクト指向設計の本はあえて入れませんでした。 というのは、以前Java系のプロジェクトをやっていたときクラス図とか一応書いたりしていたんですが、プロジェクトが佳境に入るとみんなER図しか見なくなっていたという悲しいエピソードを体験しており、やっぱりOOPよりDOAの方が実戦的なのかな?と思った経験があるからです。あとシーケンス図を書いたら、みんなpublicメソッドにロジックを詰め込んで、やたら大きなメソッドが出来上がるなんてこともありました。 5年ぐらい前の話なので、今はだいぶ状況は改善されているとは思いますが・・・。 あとフレームワーク上で開発していると、自然とレイヤアーキテクチャの形は確保されるので、新人の間はそんなにOOPを意識しなくってもいいのかな?という思いもあり、選出しませんでした。

2010年12月10日金曜日

1分間の日記で夢は必ずかなう

著者は「習慣教育の専門家」だそうです。著者はその専門領域ゆえに不登校になったり、心が弱っているような方とお会いする機会が多いらしく、そういった方々とお会いしているうちに彼らが「感じる力が弱い」、「夢がない」という共通点があると指摘しています。そして、そういった問題を克服する手段として「日記」を紹介しています。
なので、日記の書き方についてはもちろん、「夢を持つ」、「自分の感情を感じ取る力」の重要性について説くのにかなりのページを割いています。

【読書メモ】
■日記の書き方
書くことはたったの5つ!!
  1. 夢・目標
    1. 目標の書き方はなるべく具体的ではっきりと書くことが大切です。(本書より)
    2. 夢は考えるものではなく感じるものです。夢を理性で考え続けたら、あるときノルマになってしまいます。(本書より)
  2. やりたい事
  3. 今日の出来事
    1. 意外と小さな事実で何倍もの大きな妄想にふくらませてしまい、自分で自分を苦しめてしまっているのかもしれません。日記には事実と妄想は分けて記録しましょう。(本書より)
    2. 感情に対して正直になり、その感情を味わうことはとても大切なことです。
      でも感情を正直に書くあまり怒りやグチや恨みで日記が埋まってしまったのでは、せっかくの日記が「あなたの不幸をかなえる恨み日記」になってしまいます。思い切り感情を味わったあとは「感情に共感→肯定」でプラスで締めてください。(本書より)
  4. 今日の感謝
  5. 今日の成功法則・学びの言葉
    1. その日にあなたが発見したり考え付いた「あなた独自の成功法則」を記録しておきます。(本書より)
■その他の本書からの言葉色々
  • 意思を強く持つためには、実はコツがあります。それは「欲望」を強くするということです。「欲望」が強くなればなるほど、意思は強くなります。
  • 「愛情 = 理解 + 応援」
  • 今、自分自身はいったい何人の人のことを「理解」し、「応援」しているのだろうか?と自問自答すると自分はたくさんの人に理解と応援をしてもらってるくせに自分のことばかりで、あまり他人の理解と応援をしていいないことに気づきます。
  • 「自分が何を感じているか?」の問いに「正しい」、「正しくない」、「正解」、「不正解」なんてありません。
  • 大人の忙しい毎日を送っている日々ではありますが、実は楽しみと喜びが周囲にあふれているのです。
  • 忍耐は自分でも納得の上で輝かしい未来のために耐え忍ぶことです。
  • 理性は臆病です。理性は失敗を恐れます。でもだから理性は素晴らしいのです。
  • 怒りは「他人に対して、感謝が足りなくなっていること」、「自分が傲慢になってきていること」を教えてくれるのです。
  • 恐れを除くには、逃げずに行動し、正面からぶち当たる行動をすることです。そうすると恐れのほうが逃げていきます。
    もし失敗しても、逃げ続けるより最悪の結果になることはありません!何度もそういうことを重ねて、恐れは小さくなっていくのです。
  • 負けたときは、決まって周囲の人に不満を持っていたんだよね。監督への不満、指導への不満。それからは不満は持たないようにしよう。嘘でもいいから、事務の会長を好きになろうと思うようになった。そうしたらやっぱり結果は変わってくるんだよね。大事なことは油断大敵以上に不満大敵ということなんだよね。

2010年12月4日土曜日

もんじゃ焼きのおいしい焼き方

先日、嫁さんと2人でお好み焼き屋にいってきたのですが、そのとき久しぶりに「もんじゃ焼き」を注文しました。
あれの調理の仕方って
「なんとなくまぜてぐちゃぐちゃにする」
ぐらいの認識しかなくっていっつも「これっておいしいの?」という仕上がりになってしまうので、嫁さんの注文にドキドキしていたのですが、お店の店員さんが調理法を解説しながらつくってくれたんです!!
店員さんからの調理法は以下の通り。
  1. 野菜を先に炒める。このとき、ヘラを使って野菜を細かく刻んでおく。
  2. 野菜に火が通ってきたら、野菜をドーナツ状に配置する。
  3. もんじゃの生地の液体に、もんじゃのたれを入れる。
  4. ドーナツ状に配置された野菜の中心に生地の液体を入れる。このとき液体を一気にいれるのではなく、スプーン3、4杯ぐらいずつ入れるようにする。
  5. 生地にとろみがでてきたら、野菜の中心を広げつつ生地の液を足していく。
  6. 最後にもんじゃにソースをかけてかき混ぜてできあがり。
ポイントは野菜をドーナツ状に配置したときに、最初は中心の円がなるべく小さくなるようにすることと生地の液は少しずついれることだそうです。 「もんじゃっていっつも失敗するんだよな~」という同胞の方の参考になれば。

2010年11月14日日曜日

【XYZZYTips】「""」などの囲み文字を連続して入力したらカーソルを文字の間に移動させる

自分は開発作業で「XYZZY」というエディタを利用しているのですが、ネットとか見てると意外と利用者が多そうなので、自分で作ったスクリプトをちょっと公開してみようかと。

新人の頃に「"」などの囲み文字は「""」というように最初に対の形で入力して、その後に中身を書いていくという癖を付けられました。まあ、囲み文字を閉じ忘れるのにはいいと思うのですが、如何せんカーソルを一度戻して入力を続けるというのが結構面倒なんですよね。
今はPHPで仕事をしてるんですけど、PHPなんで当然HTMLタグとかも書いたりしてると、囲み文字が結構あって、その都度カーソル戻って入力するのが、結構嫌だった。

そこでXYZZYで「""」や「<>」と入力すると勝手に1文字分カーソルが戻ってくれるようなマクロを作りました。
こちらがソースになります。
;;囲み文字を入力したら、カーソルを戻して囲み文字の間にカーソルが入るようにする
(setq *backword-char-item-list* '((#\) "()") (#\] "[]") (#\} "{}") (#\' "\'\'") (#\" "\"\"") (#\> "<>")))
(defun backword-char-command-hook (list)
   (if (consp list)
      (let ((last-command (first (first list))) (back-key (first (rest (first list)))))
         (add-hook '*post-command-hook*
            #'(lambda()
               (if (and (eq *last-command-char* last-command)
                     (looking-back back-key)
                   ) (backward-char)))
         )
         (backword-char-command-hook (rest list))
      )
    ))
(backword-char-command-hook *backword-char-item-list*)
つたないコードですが、誰かの参考になれば幸いです。

2010年11月11日木曜日

脳を活性化する速読メソッド

脳を活性化する速読メソッド
呉 真由美
PHP研究所
売り上げランキング: 38181

~速読とは脳の状態である~

(本書より) 著者はテレビに出てバッティングマシンで150kmのボールを打ち返したそうです。本書でもそのエピソードが少し紹介されており、これも著者曰く速読訓練の賜物だそうです。本書は、他の速読本のようにいくつかの速読トレーニングを紹介し、速読を身につけられる構成になっています。しかし、本書は「速読は技術ではなく脳の状態である」という趣旨で統一されており紹介されているトレーニングもそれを意識したものとなっています。
【読書メモ】
■本書で紹介しているトレーニング
  1. 読書速度の計測
    6秒間で読める文字数を計測して結果を10倍にして1分間の文字数を計測します。本書では、行末に文字数が書かれているページがあり、それを利用して読書速度を計測できるようになっています

  2. 眼筋と毛様体筋のトレーニング
    下記の3種類のトレーニングをそれぞれ6秒ずつ行い回数を計測する。
    このトレーニングは眼筋を鍛える事で血流を良くする事が目的です。
    1. 顔の左右に指を立てて左右交互に指を見る。
    2. 顔の上下に指を横に出して上下交互に指を見る。
    3. 顔の10cm後、30cm後に指を立てて手前、奥と交互に指を見る。

  3. 読まずに速く見るトレーニング
    本の文字を読まずに、上下の幅を意識しながら1ページ、1秒ぐらいのペースで本を「眺める」

  4. 脳をウニュウニュするトレーニング
    これをやると脳が「ウニュウニュ」した感じになります。これは脳が活性化している証拠です。
    1. 片手でこぶしを握り足をたたき、反対の手で足をスリスリする。
    2. 本に出てくるじゃんけんのパターンを声に出しながら手は負ける手を出す。

  5. 視機能を強化するトレーニング
    5 × 5 マス内にある数字を出来るだけ速く指指していき、時間を計測する
■その他のTips色々
  • 速読でも黙読でも、各自が抱く感想はそれぞれにきっと同じ。ただ、読む時間が短くなるだけのこと。
  • 多くの人が速読は技術だと思っていらっしゃるから、「いろいろなトレーニングをたくさんしないといけない」という誤解が生まれているのでしょう。しかし、「脳がもともと持っている本当の力を引き出す」という”いちばん肝心な部分”を理解しないで、それを抜きにどんなトレーニングをやってみても、おそらく速読と言える状態にはならないはずです。

2010年10月3日日曜日

大事なことはすべて記録しなさい

大事なことはすべて記録しなさい大事なことはすべて記録しなさい
posted with amazlet at 10.10.03
鹿田 尚樹
ダイヤモンド社
売り上げランキング: 53610
Amazon.co.jp で詳細を見る

~記録は成功・成長のブースターである~

(本書より) 著者は高校時代からあらゆることを記録し続け、それによって様々な成功を手中に収めてきた方のようです。この本は著者が日々実践している記録方法を紹介しています。著者は記録のみを行い、記録した内容を分類したりしないことを奨励しています。そのかわり、常に見返したいTipsなどは「Bノート」という別のノートに集約するという方法を紹介しています。読んでいて、ここらへんは「情報はすべて1冊のノートにまとめなさい」とは違うな~と思いました。
また、議員秘書時代に培った写真や名刺を使った記録方法も紹介されており、そういった点がこの本の個性となっています。
【読書メモ】
■記録・インプット術
  1. ノート・・・A6サイズを利用する。「毎日用」と「勝負用」を使い分ける。
  2. スケジュール・・・A6サイズを利用する。ノートとサイズを合わせることで管理を楽にする。
    長期間の中で優先順位を決め手取り組めるマンスリータイプが使いやすい。
  3. ベースノート・・・机が用意された環境などで利用A5サイズを利用する。リング式を利用する。
    リング式を利用すると半分に折り曲げて利用できる。
  4. Bノート
    「自分専用の教科書」
    記録した学びの中で特に身につけたいことや記録した学びの中で特に身につけたいことや大切なことを書き写して持ち運べるようにする。
    著者は最初のページに「夢・目標」を記録している。具体的には

    短期・・・3~6ヶ月の目標
    中期・・・1年までの目標
    長期・・・3年までの目標

    を記述する。

    また他に
    1)漫画のコピー・・・やる気スイッチをいれるため
    2)読書ノートからのフレームワーク・・・仕事の成果につなげるため
    3)仕事の雛形・・・レジュメや仕事の手順などを再利用するため
    4)引用句・金言集・・・人に伝えるときに引用するため

  5. 企画・アイディアノート
    A4を利用する。テーマやコンセプトを太いマジックで書く。ボールペンは使わずシャープペンシルで書く(修正できるようにする)。
■その他のTips色々
  • 大事なことはすべて記録する。
  • 日付、時間を書く&整理・分類しない
  • シンプルに書く(「箇条書き」&キーワード)
  • 1ページ、1コンテンツ
  • 1日5分記録を読み返す。
  • 家中にペンを置く。
  • 色の力を使って記録する。
  • ネット画面はキャプチャ機能を活用する。
  • ICレコーダーを利用する(自分の話し方改善にも利用できる)。
  • 集合写真を撮る。
  • 移動中は携帯電話で記録する。
  • 音声(CD)を利用する。
  • タイムログ(時間の家計簿)を記録する。

2010年8月14日土曜日

AIRで挫折したので、JavaFXでの作成を試みる

AIRでは、結局画面のキャプチャを取る方法がなかった(みつからなかった?)ので、AIRの対抗馬と言える(?)JavaFxを利用して作ろうかと試みてみました。
HSVやRGBを変更したときの再計算の処理はJavaで実装しようとしてみたのですが、JavaFxは型なし言語で、Javaは静的な型あり言語。どうもJavaFxのスライダーの値をJavaのライブラリに渡すのが上手くいかない。誤差がすごい出て、動きがめちゃくちゃになってしまう。結局JavaFxでの開発はあきらめて、Swingを利用することに決めました。

2010年8月12日木曜日

スクリーンからのサンプリングを試みるも挫折

AIRでカラーピッカーを作ろうとしているんですが、カラーピッカーに必要な画面のキャプチャ機能を作ろうとしたのですが、色々調べてみてもAIRに画面をキャプチャする方法が見つからなかった。
色々調べた結果、クリップボードの画像を画面に貼り付けられそうだという事はわかった。
なので考えた方法があらかじめ画面をキャプチャして、それを子ウィンドウ上に表示してウィンドウ内の色をキャプチャするという方法。

2010年4月4日日曜日

カラーピッカーを作るその3(RGB変換とAIRイベント)



前回カラーピッカーを作るための画面をMXMLで作成したのですが、これにイベントをつけました。
イベントの付け方なんですが、通常は


<mx:Button x="31" y="36" label="ウィンドウ作成" click="createWindow();" />


のようにmxmlファイルのタグでイベントと呼び出すメソッドの紐付けをするのですが、これをするとビューとロジックの分離が上手く行かないのが嫌で、こちらのサイトを参考にビューとロジックを分けて見ました。




このサイトでは、<helper>タグを利用しているようですが、自分は<logic>タグを利用しました。使い方は一緒です。



  1. IMXMLObjectインタフェースを継承したオブジェクトを生成する
  2. イベントハンドラを設定するメソッドを作成する
  3. 作成したメソッドを initialized メソッドの中でFlexEvent.CREATION_COMPLETEイベントに紐づくようにする

という形になります。


HSB(色相、彩度、明度)で設定した色をRGBに変更するロジックは




から拝借しました。


ソースを全部のっけます。


colorPicker.ColorHSB.as ― HSBからRGBへの変換ロジックのあるクラス


package colorPicker {
public final class ColorHSB
{
public var h:uint = 0;    // hue
public var s:uint = 0;    // saturation
public var b:uint = 0;    // brightness

public function ColorHSB(hue:uint = 0, saturation:uint = 0, brightness:uint = 0)
{
h = hue;
s = saturation;
b = brightness;
}

public function to_object():Object
{
return {h:h, s:s, b:b };
}

public static function rgb_to_hsb(color:uint):ColorHSB
{
var r:int = (color >> 16) & 0xFF;
var g:int = (color >> 8) & 0xFF;
var b:int = color & 0xFF;

var min:int = Math.min(Math.min(r, g), b);
var max:int = Math.max(Math.max(r, g), b);

var delta:int = max - min;

var brightness:int = max;
var saturation:Number = (max == 0) ? 0 : Number(delta) / max;

var hue:Number = 0;
if (saturation != 0) {
if (r == brightness) hue = (60 * (g - b)) / delta;
else if (g == brightness) hue = 120 + (60 * (b - r)) / delta;
else    hue = 240 + (60 * (r - g)) / delta;

if (hue < 0) hue += 360;
}

return new ColorHSB(Math.round(hue), Math.round(saturation * 100), Math.round((brightness / 255) * 100) );
}

public static function hsb_to_rgb(hsb:ColorHSB):uint
{
var brightness:Number = hsb.b / 100;
if (brightness == 0) return 0;
var hue:Number = (hsb.h % 360) / 60;
var saturation:Number = hsb.s / 100;

var i:Number = Math.floor(hue);
var p:Number = (1 - saturation);
var q:Number = (1 - (saturation * (hue - i)));
var t:Number = (1 - (saturation * (1 - (hue - i))));

var r:Number, g:Number, b:Number;
switch (i) {
case 0: r = 1; g = t; b = p; break;
case 1: r = q; g = 1; b = p; break;
case 2: r = p; g = 1; b = t; break;
case 3: r = p; g = q; b = 1; break;
case 4: r = t; g = p; b = 1; break;
case 5: r = 1; g = p; b = q; break;
}

return ((Math.round(r * 255 * brightness) & 0xFF) << 16) | ((Math.round(g * 255 * brightness) & 0xFF) << 8) | (Math.round(b * 255 * brightness) & 0xFF);
}
}
}


colorPicker.ColorPickerEvent.as ― イベントハンドラを登録しているクラス


package colorPicker {
import mx.core.*;
import mx.events.*;
import colorPicker.*;
import flash.display.*;
import flash.events.*;
import flash.geom.*;
import flash.desktop.*;

public class ColorPickerEvent implements IMXMLObject
{
// 新しく生成するウィンドウを格納する変数
public var win:NativeWindow;

private var view:ColorPicker;

/**
* インタフェースから継承したメソッド
*
* @param Object document
* @param String id
*/
public function initialized(document:Object, id:String):void
{
view = document as ColorPicker
view.addEventListener(FlexEvent.CREATION_COMPLETE, creationCompleteHandler);
}


/**
* アプリケーション生成完了時に呼び出されるメソッド
*
* @param FlexEvent event
*/
private function creationCompleteHandler(event:FlexEvent):void
{
// 初期値設定
redraw(0xFFFFFF);

// イベント設定
view.colorText.addEventListener(FlexEvent.ENTER, colorTextEnterEvent);
view.tx_r.addEventListener(NumericStepperEvent.CHANGE, rgbStepperEvent);
view.tx_g.addEventListener(NumericStepperEvent.CHANGE, rgbStepperEvent);
view.tx_b.addEventListener(NumericStepperEvent.CHANGE, rgbStepperEvent);
view.rSlider.addEventListener(SliderEvent.CHANGE, rgbSliderEvent);
view.gSlider.addEventListener(SliderEvent.CHANGE, rgbSliderEvent);
view.bSlider.addEventListener(SliderEvent.CHANGE, rgbSliderEvent);
view.tx_h.addEventListener(NumericStepperEvent.CHANGE, hsvStepperEvent);
view.tx_s.addEventListener(NumericStepperEvent.CHANGE, hsvStepperEvent);
view.tx_v.addEventListener(NumericStepperEvent.CHANGE, hsvStepperEvent);
view.hSlider.addEventListener(SliderEvent.CHANGE, hsvSliderEvent);
view.sSlider.addEventListener(SliderEvent.CHANGE, hsvSliderEvent);
view.vSlider.addEventListener(SliderEvent.CHANGE, hsvSliderEvent);
}


/**
* HSVのNumericStepperが変更されたときのイベント
*
* @param NumericStepperEvent event
*/
private function hsvStepperEvent(event:NumericStepperEvent):void
{
var hsb:ColorHSB = new ColorHSB(view.tx_h.value,
view.tx_s.value,
view.tx_v.value);
var color:uint = ColorHSB.hsb_to_rgb(hsb);
redraw(color);
}


/**
* RGBのNumericStepperが変更された時のイベント
*
* @param NumericStepperEvent event
*/
private function rgbStepperEvent(event:NumericStepperEvent):void
{
var r:uint     = view.tx_r.value;
var g:uint     = view.tx_g.value;
var b:uint     = view.tx_b.value;
var color:uint = r << 16 | g << 8 | b;
redraw(color);
}


/**
* HSVのスライダーが変更された場合のイベント
*
* @param SliderEvent event
*/
private function hsvSliderEvent(event:SliderEvent):void
{
var hsb:ColorHSB = new ColorHSB(view.hSlider.value,
view.sSlider.value,
view.vSlider.value);
var color:uint = ColorHSB.hsb_to_rgb(hsb);
redraw(color);
}

/**
* RGBのスライダーが変更された場合のイベント
*
* @param SliderEvent event
*/
private function rgbSliderEvent(event:SliderEvent):void
{
var r:uint     = view.rSlider.value;
var g:uint     = view.gSlider.value;
var b:uint     = view.bSlider.value;
var color:uint = r << 16 | g << 8 | b;
redraw(color);
}


/**
* 色指定テキストに値を設定する
*
* @param uint color
*/
private function updateColorText(color:uint):void
{
var colorStr:String = rightAlign(color.toString(16), 6, "0");
view.colorText.text = "#" + colorStr.toUpperCase();
}

/**
* 指定した桁数になるまで、指定した文字列を右詰する
*
* @param String str
* @param uint   digit
* @param String fill
* @reutrn String
*/
private function rightAlign(str:String, digit:uint, fill:String):String
{
var i:int = digit - str.length;
while(i-- > 0) str = fill + str;

return str;
}

/**
* エンタキー押下時のイベント
*
*/
private function colorTextEnterEvent(event:FlexEvent):void
{
var s:String = view.colorText.text.toUpperCase();
var d:String = "";
for (var i:int = 0; i < s.length; i++) {
var c:int = s.charCodeAt(i);
if ( ( c < 48 || c > 57) && (c < 65 || c > 70 ) ) continue;
d += String.fromCharCode(c);
}
var color:uint = uint(d == '' ? 0 : '0x' + d);
redraw(color);
}


/**
* 指定された色にあわせてバーと数値を変更する
*
* @param uint color
*/
private function redrawBars(color:uint):void
{
var r:uint = (color >> 16) & 0xFF;
var g:uint = (color >> 8) & 0xFF;
var b:uint = color & 0xFF;

var hsb:ColorHSB = ColorHSB.rgb_to_hsb(color);

// 値を設定する
view.rSlider.value = r;
view.tx_r.value = r;
view.gSlider.value = g;
view.tx_g.value = g;
view.bSlider.value = b;
view.tx_b.value = b;
view.tx_h.value = hsb.h;
view.hSlider.value = hsb.h;
view.tx_s.value = hsb.s;
view.sSlider.value = hsb.s;
view.tx_v.value = hsb.b;
view.vSlider.value = hsb.b;
}


/**
* 指定した色を元に画面を再描画する
*
* @param uint color
*/
private function redraw(color:uint):void {
updateColorText(color);
view.colorCanvas.setStyle("backgroundColor", color);
redrawBars(color);
}
}
}


ColorPicker.mxml


<?xml version="1.0" encoding="utf-8"?>
<mx:WindowedApplication xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" height="380" width="560" backgroundColor="#ffffff" xmlns:logic="colorPicker.*">
<logic:ColorPickerEvent id="logic" />
<mx:HBox backgroundColor="#d4d0c8" horizontalScrollPolicy="off" verticalScrollPolicy="off" height="90%" width="100%">
<mx:VBox backgroundColor="#d4d0c8" paddingLeft="10" paddingRight="10" paddingTop="10">
<mx:HBox>
<mx:TextInput id="colorText" maxChars="7" restrict="#a-fA-F0-9"/>
</mx:HBox>
<mx:Canvas id="colorCanvas" width="200" height="200"/>
</mx:VBox>
<mx:VRule strokeColor="#808080" shadowColor="#FFFFFF" height="100%"/>
<mx:VBox paddingLeft="10" paddingTop="10">
<mx:HBox>
<mx:Label text="R" fontSize="12" fontWeight="bold" />
<mx:NumericStepper id="tx_r" maxChars="3" minimum="0" maximum="255" stepSize="1"/>
<mx:HSlider id="rSlider" minimum="0" maximum="255"
showDataTip="false"
tickColor="black"
snapInterval="1" tickInterval="10"
allowTrackClick="true"
liveDragging="true"/>
</mx:HBox>
<mx:HBox>
<mx:Label text="G" fontSize="12" fontWeight="bold" />
<mx:NumericStepper id="tx_g" maxChars="3" minimum="0" maximum="255" stepSize="1"/>
<mx:HSlider id="gSlider" minimum="0" maximum="255"
showDataTip="false"
tickColor="black"
snapInterval="1" tickInterval="10"
allowTrackClick="true"
liveDragging="true"/>
</mx:HBox>
<mx:HBox paddingBottom="20">
<mx:Label text="B" fontSize="12" fontWeight="bold" />
<mx:NumericStepper id="tx_b" maxChars="3" minimum="0" maximum="255" stepSize="1"/>
<mx:HSlider id="bSlider" minimum="0" maximum="255"
showDataTip="false"
tickColor="black"
snapInterval="1" tickInterval="10"
allowTrackClick="true"
liveDragging="true"/>
</mx:HBox>
<mx:HBox>
<mx:Label text="H" fontSize="12" fontWeight="bold" />
<mx:NumericStepper id="tx_h" maxChars="3" minimum="0" maximum="360" stepSize="1"/>
<mx:HSlider id="hSlider" minimum="0" maximum="360"
showDataTip="false"
tickColor="black"
snapInterval="1" tickInterval="10"
allowTrackClick="true"
liveDragging="true"/>
</mx:HBox>
<mx:HBox>
<mx:Label text="S" fontSize="12" fontWeight="bold" />
<mx:NumericStepper id="tx_s" maxChars="3" minimum="0" maximum="100" stepSize="1"/>
<mx:HSlider id="sSlider" minimum="0" maximum="100"
showDataTip="false"
tickColor="black"
snapInterval="1" tickInterval="10"
allowTrackClick="true"
liveDragging="true"/>
</mx:HBox>
<mx:HBox>
<mx:Label text="V" fontSize="12" fontWeight="bold" />
<mx:NumericStepper id="tx_v" maxChars="3" minimum="0" maximum="100" stepSize="1"/>
<mx:HSlider id="vSlider" minimum="0" maximum="100"
showDataTip="false"
tickColor="black"
snapInterval="1" tickInterval="10"
allowTrackClick="true"
liveDragging="true"/>
</mx:HBox>
</mx:VBox>
</mx:HBox>
</mx:WindowedApplication>



2010年3月14日日曜日

カラーピッカーを作るその2(まずはAIRで挑戦してみました)



久々の更新。
カラーピッカーを作ろうと思い立ったと書いたのですが、カラーピッカーというかやりたい事というか目標をこんな風に決めてみました。



  1. キャプチャモードにしてデスクトップ上にマウスを当てるとマウスの位置の色が拡大して表示される
  2. キャプチャモードにしてデスクトップ上にマウスを当ててクリックするとマウスの位置の色を取得することができる
  3. 取得した色を元にRGBベースで色の変更ができる
  4. 取得した色を元に色相・明度・彩度ベースで色の変更ができる

これを最初にAIRで作ろうと思いました。
というわけで、mxmlファイルで画面を作成しました。


<?xml version="1.0" encoding="utf-8"?>
<mx:WindowedApplication xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" height="380" width="560" backgroundColor="#ffffff">
<mx:HBox backgroundColor="#d4d0c8" horizontalScrollPolicy="off" verticalScrollPolicy="off" height="90%" width="100%">
<mx:VBox backgroundColor="#d4d0c8" paddingLeft="10" paddingRight="10" paddingTop="10">
<mx:HBox>
<mx:TextInput id="colorText" maxChars="7" restrict="#a-fA-F0-9"/>
<mx:Button id="subWindowButton" label="サンプリング"/>
</mx:HBox>
<mx:Canvas id="colorCanvas" width="200" height="200"/>
</mx:VBox>
<mx:VRule strokeColor="#808080" shadowColor="#FFFFFF" height="100%"/>
<mx:VBox paddingLeft="10" paddingTop="10">
<mx:HBox>
<mx:Label text="R" fontSize="12" fontWeight="bold" />
<mx:NumericStepper id="tx_r" maxChars="3" minimum="0" maximum="255" stepSize="1"/>
<mx:HSlider id="rSlider" minimum="0" maximum="255"
showDataTip="false"
tickColor="black"
snapInterval="1" tickInterval="10"
allowTrackClick="true"
liveDragging="true"/>
</mx:HBox>
<mx:HBox>
<mx:Label text="G" fontSize="12" fontWeight="bold" />
<mx:NumericStepper id="tx_g" maxChars="3" minimum="0" maximum="255" stepSize="1"/>
<mx:HSlider id="gSlider" minimum="0" maximum="255"
showDataTip="false"
tickColor="black"
snapInterval="1" tickInterval="10"
allowTrackClick="true"
liveDragging="true"/>
</mx:HBox>
<mx:HBox paddingBottom="20">
<mx:Label text="B" fontSize="12" fontWeight="bold" />
<mx:NumericStepper id="tx_b" maxChars="3" minimum="0" maximum="255" stepSize="1"/>
<mx:HSlider id="bSlider" minimum="0" maximum="255"
showDataTip="false"
tickColor="black"
snapInterval="1" tickInterval="10"
allowTrackClick="true"
liveDragging="true"/>
</mx:HBox>
<mx:HBox>
<mx:Label text="H" fontSize="12" fontWeight="bold" />
<mx:NumericStepper id="tx_h" maxChars="3" minimum="0" maximum="360" stepSize="1"/>
<mx:HSlider id="hSlider" minimum="0" maximum="360"
showDataTip="false"
tickColor="black"
snapInterval="1" tickInterval="10"
allowTrackClick="true"
liveDragging="true"/>
</mx:HBox>
<mx:HBox>
<mx:Label text="S" fontSize="12" fontWeight="bold" />
<mx:NumericStepper id="tx_s" maxChars="3" minimum="0" maximum="100" stepSize="1"/>
<mx:HSlider id="sSlider" minimum="0" maximum="100"
showDataTip="false"
tickColor="black"
snapInterval="1" tickInterval="10"
allowTrackClick="true"
liveDragging="true"/>
</mx:HBox>
<mx:HBox>
<mx:Label text="V" fontSize="12" fontWeight="bold" />
<mx:NumericStepper id="tx_v" maxChars="3" minimum="0" maximum="100" stepSize="1"/>
<mx:HSlider id="vSlider" minimum="0" maximum="100"
showDataTip="false"
tickColor="black"
snapInterval="1" tickInterval="10"
allowTrackClick="true"
liveDragging="true"/>
</mx:HBox>
</mx:VBox>
</mx:HBox>
</mx:WindowedApplication>


これで画面はできあがったので、今後は各フォームのイベント処理を今後は追加していきます。




2010年2月11日木曜日

カラーピッカーを作る


カラーピッカーを作ろうと今年のはじめに決めたのですが、早速着手してみました。

デスクトップ系のプログラミングはほとんど経験がなかったので、手探りの状態で進めていたのですが、これが思っていたよりはるかに大変というか・・・・つまずきの連続でした。

ここのブログにその経過を少しずつですが、のっけていけたらなと思います。

2010年1月29日金曜日

【連載】今からはじめるAIRプログラミングをやって



【連載】今からはじめるAIRプログラミング (1) AIRの概要とインストール方法 | エンタープライズ | マイコミジャーナル


を少しやってみました。


AIRがまだβ版だったころの記事だけあって、色々と苦戦したんですがこのサイトをやるにあたって自分がやったこととかつまずいたこととかまとめてみました。




  1. SDKを使ったコンパイル


色々ツールが紹介されているんですが、無料で開発したいというのと使ってるパソコンがCeleronマシンなので、あんまり重いツールはきついなということでSDKOnlyで勉強するようにします。
SDKのbinフォルダにパスを通して

amxmlc [ファイル名]

でAIRファイルのコンパイルができるようになります。ここはサイトに書いてある通りなので別に問題ないか・・・。




  1. fcshの利用
    mxmlのコンパイルをキャッシュすることで高速化するツールがあるんですが、これはmxmlcでしか利用できないようになっているんです。そこでaxmlcのbatファイルを確認すると

    "%~dp0mxmlc.exe" +configname=air %*

    という記述が!!axmlcはmxmlcをオプションをつけて呼び出しているだけだったようです。
    なので以下の手順でAIRアプリのコンパイルもできるようになります。

    ・fsch
    ・mxmlc +configname=air [コンパイルしたいファイル名]

    これでこのコンパイルに対してIDがふられるので、今後は

    ・mxmlc [ふられたID]

    でコンパイルができるようになります。





10個ツールを作るぞ!!



今年は頑張って10個ツールを作ることにした。


1.カラーピッカー(HSV指定機能付き)


2.ToDoリスト(オンライン上にデータを保存して、どこからでも見れるようにする)


3.関数変換&コメント生成マクロ


4.YouTubeプレイヤー


6.Timelogクライアント


7.サイボウズクライアント(未確認社内メールだけ見たい)


8.オンライン小遣い帳


10.メールテンプレート管理ツール


== その他できれば・・・


11.Googleカレンダー風Ajaxカレンダーインタフェース


12.地図検索機能ライブラリ


13.株価分析ツール





2010年1月10日日曜日

今年はAirを勉強するぞ



最近ようやく、自分の身近なところでもRIAの波が来つつあるかな~と思う今日この頃。


AjaxというかJavaScriptを利用したリッチなインタフェースについては、ちょっとかじっているので、今年はFlexとAIRを頑張って勉強しようと思う。


まずはここら辺のサイトからはじめるとしよう。


【連載】今からはじめるAIRプログラミング (1) AIRの概要とインストール方法 | エンタープライズ | マイコミジャーナル


Adobe Developer Connection





2010年1月7日木曜日

2010年度の決意!!



今年こそは、ブログを書き続けたいという固い決意の元、


こちらのブログをはじめました。


はたしてどうなることやら・・・。