2011年4月16日土曜日

GAE/J+Velocity

参考

war/WEB-INF/libにコピーしたライブラリVelocity-1.7-dep.jarをプロジェクトに追加。

control.java

protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
user user1 = new user(0, "ユーザ1", 176, 85);
user user2 = new user(1, "ユーザ2", 185, 120);
user user3 = new user(2, "ユーザ3", 168, 72);
LinkedList group = new LinkedList();

group.add(user1);
group.add(user2);
group.add(user3);

Velocity.init();
VelocityContext vc = new VelocityContext();
vc.put("group", group);
StringWriter sw = new StringWriter();
Template template = Velocity.getTemplate("/admin/velocity/foreach.vm", "UTF-8");

template.merge(vc, sw);
System.out.println(sw);
resp.setCharacterEncoding("UTF-8");
resp.setContentType("text/html; charset=UTF-8");
resp.getWriter().print(sw);
}

web.xml

<servlet>
<servlet-name>control</servlet-name>
<servlet-class>scoreman.control</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>control</servlet-name>
<url-pattern>/admin/control</url-pattern>
</servlet-mapping>

war/admin/velocity/foreach.vm



<html>
<body>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<h1>Velocity</h1>
表示のテストです<br>
#easyMacro($group)
</body>
</html>

#macro(easyMacro $group)
#foreach($human in $group)
$velocityCount : $human.name<br>
#end
#end

参考サイトでは文字化け対策でpropertyファイルをコピーしてたりしてたけど、今のところこれでも問題ないのでこれでいきますかな。


表示画面


無題

Flex勉強会第136回@東京(2011年4月13日)

Photo 4月 16, 0 27 33

に参加してきました。

FlexUserGroupの略でfxugといわれる集まりのようです。

今回は就活のネタとして行ったわけで、勉強会は初めてでしたが一流の技術者を目指すべく今何をすればいいかな~?って考えた結果。自分にはこれがぴったりだったわけです。

会場は大崎にあるAdobeのオフィスの一画で、洒落乙だったから緊張したわ。

Flexについては2年前にちょろっといじっただけでしたが1.5/3の内容は理解したつもりです。
Flexの本書いてる人だったり、フレームワーク作っちゃったりしてる人の発表でいい刺激を受けましたわ。

最後に本のプレゼントやらタンブラーのじゃんけんやらでプレゼントも豊富!
いやしんぼの私にはぴったりですね!

次回は何に参加しましょうかね?

2011年4月12日火曜日

Velocity

HTMLのテンプレートに変数を代入してから表示させる事が出来る。
他にもテキストファイルなら埋め込み可能。

これによって構成とデータを別々に管理しやすくなると。

eclipse用は→ここ
velocity-1.7.zip
この中のvelocity-1.7-dep.jarを使用。

参考

テンプレート:index.vm

識別番号:$user.id
名前:$user.name
体重:$user.weight
身長:$user.height



データクラス:user.java
public class user {
private int id = 0;
private String name = "";
private int weight = 0;
private int height = 0;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getWeight() {
return weight;
}
public void setWeight(int weight) {
this.weight = weight;
}
public int getHeight() {
return height;
}
public void setHeight(int height) {
this.height = height;
}
public user(int id, String name, int weight, int height) {
this.id = id;
this.name = name;
this.weight = weight;
this.height = height;
}
public user() {}

}



マージクラス:test.java
import java.io.StringWriter;

import org.apache.velocity.Template;
import org.apache.velocity.VelocityContext;
import org.apache.velocity.app.Velocity;

public class test {
public static void main(String[] args) {
user user = new user(1000, "銅鑼 衛門", 100, 200);
Velocity.init();
VelocityContext context = new VelocityContext();
context.put("user", user);

StringWriter stringWriter = new StringWriter();
Template template = Velocity.getTemplate("index.vm", "UTF-8");
template.merge(context, stringWriter);
System.out.println(stringWriter.toString());
stringWriter.flush();
}
}
 

2011年4月7日木曜日

GoogleMapsAPI V3で出来ること

  • ちょろっとコードを書くだけでGoogleMapが自分のサイトに張り付けられる。
  • 座標や住所によってピンを置くことが出来る。
  • ルートの作成が可能
    →中継地点も追加でき、巡回セールスマン問題を解いてくれるw
  • JavaScript、Flash、画像、3Dなどいろいろな形式が用意されている。
    →PCからだったらJavaScript、モバイルだったら画像表示とかが可能。
  • GoogleMap上やピンなどのイベントを処理できる。
    →「クリックでズームする」など。

チュートリアルや解説が非常にわかりやすい
Google Map JavaScript API V3 チュートリアル

GoogleMapsAPI V3 複数マーカーの単一表示

Google Maps API v3でv2のように、1つだけの情報ウィンドウが開くようにする(1)

2011年4月4日月曜日

ライブラリ

ライブラリは「war」→「WEB-INF」→「lib」に配置してからプロジェクトで指定。

~jericho~
クラス・フォルダーを追加したらローカルでは動くがサーバ側でエラー。
JARファイルにしたら動いた。

URLフェッチ

URL url = new URL(req.getParameter("url"));
BufferedReader reader = new BufferedReader(new InputStreamReader(url.openStream()));
String line;
String html = new String();

while((line = reader.readLine()) != null){
 html += line + "\n"
}
reader.close();