[Flash]How to detect flash player version

前一篇文章提到的 chart 是別人家做好的 flash 元件,所以很多地方都有受限,現在有人反映 flash player 6 看不到 chart,好吧,既然有人反應那就來找找怎麼去判斷 browser 的 flash player 版本(心中OS:現在 flash 版本都到 9 了麻煩升個級好嗎? -__-)…

我找到兩個方式:

一、在 object tag 上加上 codebase 指定版本

<object classid="xxx" codebase="http://fpdownload.macromedia.com/pub/shockwave/cabs/
flash/swflash.cab#version=8,0,0,0″ … >

</object>

但是 FF2 好像不太吃這一套…

二、 用 JS 判定

詳見 這裡,這應該是最穩的辦法…

不過還真是有點小麻煩,若是在做 flash 的時候就加上檢查版本的功能,那不就沒這麼多事了嗎? 唉~

發表迴響

[JavaScript]How to set resize event in IE & FF2

前陣子,為了 layout 上的 flash chart 能夠 liquid width,在 try error 了無數次之後,好不容易找到最簡單能夠重新 render chart 的方式,卻栽在設定 resize 的 event 上,在 IE 上只要在 tag 上加上 onresize="xxx" 就OK,FF2 就不吃這一套,屢試不爽

(╯ ̄皿 ̄)╯︵┴─┴

查了一下資料,原來 FF2 的 resize 只有在 window 物件上才有,而且是叫〝resize〞不是〝onresize〞,好吧,那就設成 window resize 吧..

BUT, 我以為我找到關鍵的所以應該沒問題了,錯錯錯~~ 原來 IE & FF2 的 event 指定方式不一樣啊~~~~

好吧, 再去問了谷歌得到解答如下:

// if FF2
if(window.addEventListener)
{
window.addEventListener(‘resize’, function(){render_chart();}, false);
}
// if IE
if(window.attachEvent)
{
window.attachEvent(“onresize", function(){render_chart();});
}

唉~ 真是麻煩~

迴響數(3)

[Ubuntu]Ubuntu 更改時區

今早因某台 Server 時間不正確,所以 Google 了一下 ubuntu 更改時區的用法

以下作法 參考至 调整更改ubuntu时区鳥哥的 Linux 私房菜-NTP 時間伺服器

$ sudo tzselect
依選項選擇你在的時區

$ sudo cp /usr/share/zoneinfo/Aisa/Taipei /etc/localtime
更換時區檔

$ sudo ntpdate time.stdtime.gov.tw
對時,其它台灣的 Time Server 請參考 國家時間與頻率標準實驗室 的說明

$ sudo hwclock -w
將時間寫入 BIOS

$ sudo crontab -e
@daily /usr/sbin/ntpdate time.stdtime.gov.tw > /dev/null
將對時寫進 crontab 每天做一次

迴響數(1)

[ActiveRecord]Dynamic attribute-based finders

說明:(節錄至ActiveRecord::Base)
Dynamic attribute-based finders are a cleaner way of getting (and/or creating) objects by simple queries without turning to SQL.

用法:

可以簡單利用 find_by_xxx or find_all_by_xxx 來取得資料(xxx => column name)
ex: Person.find_by_user_name(user_name)

也可使用複數的條件(and/or)來取得資料
ex: Person.find_by_user_name_and_password(user_name, password)

最最最好用的就是這個功能,先判斷資料是否存在,若存在回傳此筆資料,若不存在 create 這筆資料
ex:
# No 'Summer' tag exists
Tag.find_or_create_by_name("Summer") # equal to Tag.create(:name => "Summer")
# Now the 'Summer' tag does exist
Tag.find_or_create_by_name("Summer") # equal to Tag.find_by_name("Summer")

或是不想直接 create 只是先初始化一個新的物件的話
ex:
# No 'Winter' tag exists
winter = Tag.find_or_initialize_by_name("Winter")
winter.new_record? # true

這些finders實在是方便,故特別記一筆以免忘記~

迴響數(1)

[DRB]Distributed Ruby Objects Simple Sample

Distributed Ruby Objects (以下簡稱 drb),是 Ruby Standard Library 中用來做到類似 RPC (Remote procedure call) 的函式庫,以下紀錄最基本的 Server 端和 Client 端的 sample。

Server:

require ‘drb’

class TimeServer

def get_current_time
Time.now
end

def stop_server
DRb.stop_service
end

end

uri = ‘druby://localhost:7788′
front_object = TimeServer.new

DRb.start_service(uri, front_object)

# Wait for the drb server thread to finish before exiting.
DRb.thread.join

這樣一來最簡單的 Server 端就OK了,只要執行這段 Ruby code,Client端就可以用 druby://localhost:7788 來叫用服務。

Client:

require ‘drb’

server_uri = “druby://localhost:7788″

timeserver = DRbObject.new_with_uri(server_uri)

#call remote object method ‘get_current_time’
puts timeserver.get_current_time

#stop remote service
timeserver.stop_server

就這麼簡單,不過方便歸方便,安全的問題也要特別注意

若想深入了解的人可以參考以下連結:

Intro to DRb
drb: Ruby Standard Library Documentation

發表迴響

如何在寫一般 Ruby Code 時使用 Rails 的 ActiveSupport

就只要改一行:

require “rubygems"
require “active_support"

就這麼簡單,害我找半天,本以為要像使用 ActiveRecord 般

require “rubygems"
require_gem “activerecord"

依樣畫葫蘆的結果完全沒反應

require “rubygems"
require_gem “activesupport"

怎麼會這樣勒?????
在Google中也沒找到相關資料,我記得require_gem “activerecord" 之後除了ActiveRecord外還可直接使用ActiveSupport,但若只想使用ActiveSupport的功能把整個ActiveRecord都require進來實在太肥,索性直接進 ActiveRecord 的原始碼裡面看到底是怎麼弄的,結果改一行就解決~~

YA~~ 以後可以直接使用 1.days.ago 或是 Time.now.tomorrow 這類簡單的表示法啦~~~

Rails萬歲~~~ OpenSource 萬歲~~~~~

迴響數(2)

[Ruby] dump excel data example.

require 'win32ole'

def getAbsolutePath filename
  fso = WIN32OLE.new('Scripting.FileSystemObject')
  return fso.GetAbsolutePathName(filename)
end

filename = getAbsolutePath("sample1.xls")
xl = WIN32OLE.new('Excel.Application')
book = xl.Workbooks.Open(filename)

begin
book.Worksheets.each do |sheet|
  sheet.UsedRange.Rows.each do |row|
    record = []
    row.Columns.each do |cell|
      record << cell.Value
    end
    puts record.join(",")
  end
end

ensure 
  book.Close
  xl.Quit
end

Reference: Win32OLE 活用法 【第 2 回】 Excel

迴響數(2)

Older Posts »
Follow

Get every new post delivered to your Inbox.