25/09/2013

Remote deploy Tomcat application using Maven

Configure Tomcat servers for Maven:

Open ~/.m2/settings.xml (if it doesn't exist, create it), add the following lines:
  <settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" 
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0
                      http://maven.apache.org/xsd/settings-1.0.0.xsd">
<servers>
      <!-- Omit the irrelevant information here -->
      <server>
        <id>Tomcat7</id>
        <username>tomcat</username>
       <!-- Change this password -->
        <password>mypassword</password>
      </server>
     <!-- Omit the irrelevant information here -->
  </servers>
</settings>


Configure pom.xml:

Add the plugin for Maven:

<plugin>
            <groupId>org.codehaus.mojo</groupId>
            <artifactId>tomcat-maven-plugin</artifactId>
             <version>1.1</version>
            <configuration>
                <server>Tomcat7</server>
                <!-- Change the name of your server -->
                <url>http://example.com:8080/manager/text</url>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-war-plugin</artifactId>
            <version>2.3</version>
            <configuration>
                <packagingExcludes>WEB-INF/web.xml</packagingExcludes>
            </configuration>
 </plugin>
                


Configure Tomcat:

Open file /conf/tomcat-users.xml:


   <tomcat-users>
   <role rolename="manager-gui"/>
   <role rolename="manager-script"/>
   <user username="tomcat" password="mypassword" roles="manager-gui,manager-script"/>
</tomcat-users>
   
   


Using:

Run your application with goal tomcat:redeploy the application will be redeployed to remote server.

23/09/2013

Thay đổi hostname của máy Mac OS X

Do nhu cầu quản lý hoặc để chia sẻ dữ liệu giữa các thành viên trong nhóm dễ dàng hơn chúng ta cần thay đổi hostname của máy tính đang sử dụng hệ điều hành Mac OS X của chúng ta. Để xem hostname hiện tại sử dụng câu lệnh sau trong cửa sổ Terminal:
hostname
Để thay đổi hostname chúng ta sử dụng câu lệnh sau trong cửa số Terminal:
sudo scutil –-set HostName new_hostname
Lưu ý rằng phía trước chữ set là dấu dash (--) chứ không phải dấu hyphen (-)
Nếu bạn chỉ muốn thay đổi hostname tạm thời và hostname sẽ bị thiết lập lại sau khi bạn khởi động lại hệ thống thì sử dụng câu lệnh sau đây trong cửa số Terminal:
sudo hostname new_hostname

15/06/2013

Which criteria for a successful software project


Thay đổi kích thước view khi user thay đổi paper orientation

Đôi khi chúng ta gặp tình huống là chúng ta muốn thay đổi thuộc tính của view cho phù hợp với orientation của trang giấy khi user chọn trên print panel.
NSPrintOperation*fPrintOperation = [NSPrintOperation printOperationWithView:viewToPrint];
    [fPrintOperation.printInfo setOrientation:NSLandscapeOrientation];
    [fPrintOperation.printPanel setOptions:NSPrintPanelShowsPreview|NSPrintPanelShowsPaperSize|NSPrintPanelShowsPageRange|NSPrintPanelShowsCopies|NSPrintPanelShowsOrientation];  
    [NSPrintOperation setCurrentOperation:fPrintOperation];
    if(fPrintOperation.printPanel.runModal == NSOKButton){      
        NSPrintInfo*printInfo = [fPrintOperation printInfo];
        if( [printInfo orientation] == NSPortraitOrientation){
           //Do something
        }else{
           //Do something
        }
        [[NSPrintOperation currentOperation] cleanUpOperation];
        NSPrintOperation *rPrintOperation = [NSPrintOperation printOperationWithView:viewToPrint printInfo:printInfo];
        [rPrintOperation setShowsPrintPanel:NO];
        [rPrintOperation runOperation];
    }else{
        [[NSPrintOperation currentOperation] cleanUpOperation];
    }

18/05/2013

Bind edit shortcuts cho chương trình Mac OS X

Lập trình Mac OS X, ai cũng biết rằng để bind các edit shortcuts như Cmd-C, Cmd-V, Cmd-A, ... cho chương trình chúng ta thường sử dụng built-in Edit menu. Tuy nhiên trong vài trường hợp chúng ta cần customize menu bar nên không có built-in Edit menu trên menu bar. Trong trường hợp này chúng ta thực hiện theo phương pháp sau:

  1. Kế thừa NSApplication, tạo lớp CustomApplication:
    • CustomApplication.h:
      @interface CustomApplication:NSApplication
      @end
    • CustomApplication.m
      @implementation CustomApplication
      - (void) sendEvent:(NSEvent *)event {
          if ([event type] == NSKeyDown) {
              if (([event modifierFlags] & NSDeviceIndependentModifierFlagsMask) == NSCommandKeyMask) {
                  if ([[event charactersIgnoringModifiers] isEqualToString:@"x"]) {
                      if ([self sendAction:@selector(cut:) to:nil from:self])
                          return;
                  }
                  else if ([[event charactersIgnoringModifiers] isEqualToString:@"c"]) {
                      if ([self sendAction:@selector(copy:) to:nil from:self])
                          return;
                  }
                  else if ([[event charactersIgnoringModifiers] isEqualToString:@"v"]) {
                      if ([self sendAction:@selector(paste:) to:nil from:self])
                          return;
                  }
                  else if ([[event charactersIgnoringModifiers] isEqualToString:@"z"]) {
                      if ([self sendAction:@selector(undo:) to:nil from:self])
                          return;
                  }
                  else if ([[event charactersIgnoringModifiers] isEqualToString:@"a"]) {
                      if ([self sendAction:@selector(selectAll:) to:nil from:self])
                          return;
                  }
              }
              else if (([event modifierFlags] & NSDeviceIndependentModifierFlagsMask) == (NSCommandKeyMask | NSShiftKeyMask)) {
                  if ([[event charactersIgnoringModifiers] isEqualToString:@"Z"]) {
                      if ([self sendAction:@selector(redo:) to:nil from:self])
                          return;
                  }
              }
          }
          [super sendEvent:event];
      }
      @end
  2. Thay đổi NSApplication thành CustomApplication trong mục Principal Class ở Target properties.
       

11/05/2013

Lưu ý khi dùng NSColor trong MAC OS X programming

Trong khi lập trình MAC OS X bạn sẽ gặp phải vấn đề sau đây:
Khách hàng đưa cho bạn màu sắc của một bản thiết kế nào đó dạng chuỗi HTML RGB ví dụ: 6F5A4E và yêu cầu bạn đưa lên màn hình. Thông thường bạn sẽ làm như sau:
Tạo category cho NSColor để thêm phương thức tạo NSColor từ chuỗi HTMLRGB:
  • Tạo file NSColor+Ext.h:
       @interface NSColor(Ext)
       +(NSColor*) newColorFromRGBString:(NSString*) rgb;
      @end
    
  • Tạo file NSColor+Ext.m
    @implementation NSColor(Ext)
        +(NSColor*) newColorFromRGBString:(NSString*) rgb{
    
            NSColor*result= nil;
    
            unsigned colorValue=0;
    
            unsigned char  r,g, b;
        if (nil != rgb)
        {
             NSScanner* scanner = [NSScanner scannerWithString:rgb];
              // ignore error
             (void) [scanner scanHexInt:&colorValue];
        }
        r = (unsigned char)(colorValue >> 16);
        g = (unsigned char)(colorValue >> 8);
        // masks off high bits
        b = (unsigned char)(colorValue);
        result = [NSColor colorWithCalibratedRed:(CGFloat)r / 0xff green:(CGFloat)g / 0xff blue:(CGFloat)b / 0xff alpha:1.0f];
        return result;
       }
    @end
    
Đoạn code trên có vấn đề ở chỗ là chúng ta sử dụng phương thức colorWithCalibratedRed:green: blue:, màu sắc hiện lên trên màn hình chỉ đúng khi người dùng chọn Generic RGB Profile trong System Preferences > Display > Color. Nếu người dùng chọn color profile khác thì màu sắc hiện lên màn hình không như bạn mong đợi. Bạn có thể sử dụng công cụ đo màu (color picker) để kiểm chứng điều này.
Sau đây mình sẽ trình bày phương pháp để giải quyết vấn đề này bằng ColorSync Manager API (Xem thêm tài liệu Technical Q&A QA1396):
  1. Khai property colorSpace trong AppDelegate.h:
    @interface AppDelegate:NSObject
    @property (strong) NSColorSpace*colorSpace;
    @end
    
  2. Trong AppDelegate.m Private category:
    #import <ApplicationServices/ApplicationServices.h>
    @interface AppDelegate()
    +(CGColorSpaceRef)CreateDisplayColorSpace;
    -(void)updateColorSpace;
    -(void)registerNotifications;
    @end
    @implementation AppDelegate
    //Disable deprecated warning
    #pragma GCC diagnostic ignored "-Wdeprecated-declarations"
    +(CGColorSpaceRef)CreateDisplayColorSpace{
    CMProfileRef sysprof = NULL;
        CGColorSpaceRef dispColorSpace = NULL;
    
        // Get the Systems Profile for the main display
        if (CMGetSystemProfile(&sysprof) == noErr)
        {
            // Create a colorspace with the systems profile
            dispColorSpace = CGColorSpaceCreateWithPlatformColorSpace(sysprof);
    
            // Close the profile
            CMCloseProfile(sysprof);
        }
    
        return dispColorSpace;
    }
    //Enable deprecated warning
    #pragma GCC diagnostic warning "-Wdeprecated-declarations"
    -(void)registerNotifications
    {
        NSDistributedNotificationCenter *center;
    
        center = [NSDistributedNotificationCenter defaultCenter];
    
        [center addObserver:self
                   selector:@selector(updateColorSpace)
                       name:kCMDeviceUnregisteredNotification
                     object:nil];
        [center addObserver:self
                   selector:@selector(updateColorSpace)
                       name:kCMDefaultDeviceNotification
                     object:nil];
        [center addObserver:self
                   selector:@selector(updateColorSpace)
                       name:kCMDeviceProfilesNotification
                     object:nil];
        [center addObserver:self
                   selector:@selector(updateColorSpace)
                       name:kCMDefaultDeviceProfileNotification
                     object:nil];
    }
    -(void)updateColorSpace{
     CGColorSpaceRef csr = [AppDelegate CreateDisplayColorSpace];
     self.colorSpace = [[NSColorSpace alloc] initWithCGColorSpace:csr];
    CGColorSpaceRelease(csr);
    }
    - (void)applicationWillFinishLaunching:(NSNotification *)aNotification{
    [self registerNotifications];
    [self updateColorSpace];
    } @end
  3. Nhiệm vụ cuối cùng là thay đổi cách viết NSColor+Ext ở trên dùng property colorSpace trong lớp AppDelegate:
        @implementation NSColor(Ext)
        +(NSColor*) newColorFromRGBString:(NSString*) rgb{
             NSColor* result = nil;
             unsigned colorValue = 0;
             unsigned char r, g, b;
             if (nil != rgb)
              {
                    NSScanner* scanner = [NSScanner scannerWithString:rgb];
                    // ignore error
                    (void) [scanner scanHexInt:&colorValue];
              }
              r = (unsigned char)(colorValue >> 16);
              g = (unsigned char)(colorValue >> 8);
              // masks off high bits
              b = (unsigned char)(colorValue);
              CGFloat components[4] = {(CGFloat)r / 0xff,(CGFloat)g / 0xff,(CGFloat)b / 0xff,1.0f};
              return [NSColor colorWithColorSpace:(AppDelegate*)([NSApplication shareApplication].delegate).colorSpace components:components count:4];
              }
         @end
            

01/05/2013

NCTDownloader version 1.0.0.0

Hôm nay rãnh rỗi ngồi viết code cho bài viết: Tải nhạc (phim) từ trang nhaccuatui.com.
Chương trình này tạm gọi là NCTDownloader. Phiên bản 1.0.0.0 download về tại đây.
Ở phiên bản này  NCTDownloader chỉ lấy link download trực tiếp bài nhạc hay video clip.

02/04/2013

Cài đặt custom FontAndColorTheme in XCode

Download file FontAndColor miễn phí ở một số trang như sau:

  • http://amychr.wordpress.com/2011/06/05/xcode-color-themes/
  • http://undefinedvalue.com/2012/10/30/havenjark-color-theme-xcode-4
Sau đó chép tập tin này vào thư mục:
~/Library/Developer/Xcode/UserData/FontAndColorThemes

22/03/2013

OpenGL blend function

Trước đây làm việc OpenGL mà không hiểu mấy về cái hàm gl.glBlendFunc(a,b). Hôm qua có thời gian ngồi xem tài liệu kỹ lại thì ra là thế này. Gọi D là màu của destination (màu đang có), S là màu source (màu ta cần pha với màu đang có), ta có công thức tính màu sau khi pha như sau:
R = a*S+b*D
Lấy ví dụ: 
  • Nếu a= GL_ONE, b=GL_ONE, S=(1,0,0) (màu đỏ), D=(0,0,1) (xanh da trời). Ta sẽ có R=(1,0,1) (màu đỏ tươi)
  • Nếu a=GL_SRC_ALPHA, b= GL_ONE_MINUS_SRC_ALPHA, S=(0.5,1,0,0), D=(1,0,0,1). Ta sẽ có: 
    • Ra = 0.5*0.5+(1-0.5)*1=0.25+0.5 = 0.75
    • Rr = 0.5*1+(1-0.5)*0 = 0.5
    • Rg = 0.5*0+(1-0.5)*0 = 0
    • Rb = 0.5*0+(1-05)*1 = 0.5
                R = (0.75,0.5,0,0.5)



20/03/2013

ARC in Mac OS X 10.6.8

Một ngày vật lộn với việc build app với ARC chạy trên Mac OS X 10.6.8 bằng XCode 4.6.1 (Lưu ý: XCode 4.6 có bug khi build app với ARC  chạy trên Mac OS X 10.6.8). Nếu tạo một Project mới với ARC được bật thì mọi việc OK. Tuy nhiên khi add mấy file mã nguồn vào thì cứ bị lỗi:
Symbol not found: _objc_retain
Thử đủ cách lượm lặt từ Google như:

  • Add -fobjc-arc vào Other linker flags.
  • Sử dụng -weak_library, -weak_framework.
  • Tắt Implicit link to system library option
Cuối cùng cũng tìm ra lời giải. ARC trên 10.6.8 không hỗ trợ các phương thức + (void) initialize+(void) load.


15/03/2013

Kiểm tra một số có là luỹ thừa của 2 hay không nhanh nhất

Thông thường để muốn kiểm tra một số có là luỹ thừa của 2 hay không thì chúng ta đem số này chia cho 2 như sau:

public boolean isPowerOfTwo(int n){
	if( 0 == n|| 1 == n ) return true;
	int x = n / 2;
	int y = n%2;
	if (1 == y) return false;
	return isPowerOfTwo(x);
}
Hoặc chúng ta không cần viết đệ qui như sau:

  public boolean isPowerOfTwo(int n){
    boolean ret;        
	if( 0 == n|| 1 == n ){
    	     ret = false;       
    }else{
        int x = n / 2;
        int y = n%2;
        while ( x > 0){
        	if (1 == y) {
            ret = false;
            break;
 		};
		x = x / 2;
        y = x%2;
	}
	ret = true;
	}
   return ret;
 } 

Sau đây là cách nhanh hơn sử dụng hàm logarit:

public boolean isPowerOfTwo(int n){
	double logn2 = Math.log(n)/Math.log(2);
	int logn2i = (int) (Math.floor(logn2));
	if(logn2-logn2i==0)
		return true;
	else
	return false;
}

Tuy nhiên nếu chúng ta để ý một chút chúng ta sẽ có cách kiểm tra nhanh nhất. Các số là luỹ thừa của 2 đều có 1 chữ số 1 trong biểu diễn nhị phân của chúng. Ví dụ số
1: 000001
2: 000010
4: 000100
8: 001000
16: 010000
32:     100000
Xét số n = 32 ( 100000) và n -1 = 31 (011111) và rõ ràng n&(n-1) = 0.
Ta có giải thuật như sau:

public boolean isPowerOfTwo(int n){
	return ((n!=0) && (n&(n-1))==0);
}

Thật ngắn gọn, đơn giản phải không các bạn!

16/02/2013

Android 4.2.2 (JDQ39) changelog

Google has release Android 4.2.2 (Jelly Bean). Nexus tablets ( Nexus 7 (non-3G), Nexus 10) and Galaxy Nexus (takju) can be updated the new version OS. Some changes:

  • More secured ADB.
  • Bug fix for bluetooth audio streaming
  • Download notification now shows remaining time
  • Quick Settings:Toggle WiFi and Bluetooth on/off by a long-touch 
  • Performance enhancements
  • New notification sounds (wireless charging and low battery)
Google vừa phát hành bản nân cấp Android 4.2.2. Các smartphone Nexus 4, Galaxy Nexus và máy tính bảng Nexus 7, Nexus 10 đã có thể cập nhật bản Android 4.2.2.
Một vài điểm mới trong bản nâng cấp Android 4.2.2:
  • An toàn hơn cho cầu nối ADB.
  • Vá lỗi âm thanh bị lắp khi dùng Bluetooth và lỗi tự khởi động lại thiết bị.
  • Thông báo (Notification) tải ứng dụng trình bày thông tin về thời gian còn lại cần để tải.
  • Thiết lập nhanh (Quick Settings):Người dùng có thể chạm vào và giữ lâu (long touch) lên biểu tượng Wi-Fi và Bluetooth để thay đổi thiết lập.
  • Âm báo mới cho chức sạc không dây và cảnh báo pin sắp hết.
  • Tốc độ hiển thị và lướt ảnh trong Gallery nhanh hơn.

04/01/2013

Hệ điều hành dành cho Smartphone năm 2013


  • Ubuntu trình làng hệ điều hành dành cho smartphone Ubuntu for phone (UFP). UFP dựa trên bản Ubuntu dành ch o PC. Mẫu điện thoại di động dùng UFP sẽ ra mắt vào CES 2013 ở Las Vegas từ 8/1-11/1. Các ứng dụng chạy trên UFP là các ứng dụng HTML5 hay các ứng dụng Qt/QML.
  • Apple thử nghiệm iOS7 và iPhone thế hệ thứ 6.
  • Smartphone Tizen sẽ ra đời vào năm 2013: Tizen là sự kết hợp giữa MeeGo và LiMo được tài trợ bởi Intel và Samsung. Samsung và NTT Docomo đang hợp tác để năm 2013 này, điện thoại sử dụng Tizen sẽ ra đời. Ngoài ra Vodafone, France Telecom,Panasonic, NEC cũng đang phát triển thiết bị sử dụng Tizen.
  • Jolla trình làng Sailfish OS dự trên Mer tại Phần Lan.
  • Mozilla thử nghiệm Firefox OS.
  • RIM tuyên bố sẽ cho ra lò smartphone sử dụng Blackberry 10 trong năm 2013.

03/01/2013

Khắc phục lỗi trùng ObjectID trong XCode 4.5

Một dự án Mac OS bạn sử dụng các phiên bản cũ (4.3-) để phát triển. Sau một khoảng thời gian bạn đã nâng cấp XCode lên phiên bản 4.5. Lúc này bạn mở lại các dự án cũ, thỉnh thoảng bạn gặp lỗi sau:
The document "name.xib" could not be opened. The operation couldn’t be completed. Two members of the document have the object ID 17. This may have happened through an external edit, such as an SCM merge operation.
Trường hợp của bạn có thể không phải object ID 17 mà là một con số khác.
Để khắc phục lỗi này chúng ta mở nib file bị lỗi trong trường hợp này là name.xib bằng text editor và tìm cụm ">17" (thay số 17 bằng số trong trường hợp của bạn). Thay đổi số này bằng một số lớn lớn rồi lưu lại. 

31/12/2012

Cắt số lẻ trong số double

Trong các phần mềm tài chính, ngân hàng thường có bài toán như sau:
Cho một số double, bạn hãy cắt bỏ các số lẻ sau số lẻ thứ k trong phần thập phân.
Đứng trước bài toán này bạn thường nghĩ đến giải pháp cắt chuỗi. Biến double sang NSString rồi cắt chuỗi.
Tuy nhiên khi bạn chuyển số double sang NSString bằng string format %.*f bạn sẽ gặp phải vấn đề làm tròn số lên. Bạn lại nghĩ ra vậy tôi lấy đến k+1 số lẻ rồi cắt bỏ chữ số cuối cùng.Tuy nhiên giải pháp này lại bị vấn đề làm tròn số lan truyền khi chữ số thứ k+1 là số 9. Để tránh làm tròn số lan truyền một bạn khác lại đề nghị chuyển double sang NSNumber trước khi chuyển sang NSString. Một điều không may cho giải pháp này khi bạn chuyển các số double như 1.05, 0.05 thì bạn sẽ nhận được các số 1.049999..., 0.049999,.. (xem bài viết Vấn đề làm tròn số khi dùng double). Ngoài ra bạn cũng có thể nghĩ đến các hàm C khác khi modf, ... F giới thiệu cách sử dụng hàm floor như sau:
floor(x*pow(10,k)+1E-10)/pow(10,k) 

29/12/2012

Chạy ứng dụng Android trên PC

Đọc các bài báo sau  trên báo Tuổi trẻ:

và đang suy nghĩ miên man về công nghệ mà Blue Stacks sử dụng.Ngoài ra liệu việc làm này sẽ làm cho Android mạnh lên hay sẽ thu hẹp tầm ảnh hưởng của nó?
Về công nghệ thì theo các bài báo có chút thông tin tóm tắt như sau:

  • BlueStacks sử dụng BlueStacks App Player (BAP) 
  • BAP thực hiện giải pháp chuyển đổi ảo hoá Windows/Mac OS nhanh chóng thông qua công nghệ đám mây BlueStack Cloud Connect 
  • Cho phép đồng bộ ứng dụng trên Android smartphone với PC.

VẤN ĐỀ LÀM TRÒN SỐ KHI DÙNG DOUBLE

Có bao giờ bạn gặp rắc rối khi gán 0.05 vào 1 biến double:
double f = 0.05
Rồi sau đó bạn tính
floor(f*100)
Bạn mong đợi nhận được 5. Tuy nhiên kết quả bạn nhận được lại là 4.
Để tìm hiểu nguyên nhân tại sao như vậy chúng ta bắt đầu tìm hiểu từ cách thức lưu số double trong bộ nhớ ra sau.
Số double sử dụng 8 byte hay 64 bit để lưu. Trong đó:

  • 1 bit dùng để lưu dấu của số double (sign bit)
  • 11 bit dùng để lưu độ lớn của số mũ (exponent)
  • 52 bit + 1 bit có giá trị mặc định để lưu phần định trị (mantissa)
value =(-1)sign(1.b-1b-2..b-52)2x 2e-1023=(-1)sign(SUMi=1,52(b-i2-i))x 2e-1023 trong đó e là số mũ
Vậy độ chính xác (machine epsilon) khi làm tròn là 2-53 do khoảng cách giữa hai số 2n và 2n+1 là 2n-52
Phần số mũ e được biểu diễn dạng offset-binary (excess-K) K=2n-1 với n là số bit. Ở đây n = 11.
Giá trị của số = (-1)signx 2exponent - 1023x1.mantissa
Bây giờ ta hãy xem số 0.05 lưu trong bộ nhớ ra sao?
0.05 = 0.00001100110011001100110011001100110011001100110011001100... =  0.1100110011001100110011001100110011001100110011001100... x 2-4
Phần sau dấu phẩy bị cắt 52 bít là:
110011001100110011001100110011001100110011001100110
Bây giờ bạn tính lại sẽ thấy giá trị là:
0.049999999999999988897769753748434595763683319091796875
Rõ ràng số này nhân với 100 và tính floor là 4 chứ không phải là 5.
Để lấy floor chính xác bạn cần cộng thêm một lượng 10-N. Trong đó N là số chữ số bạn quan tâm.

25/12/2012

LƯU Ý KHI RESHOW UIPOPOVERCONTROLLER

Vì một lý do nào đó bạn phải reshow lại UIPopoverController ví dụ như bạn phải canh giữa màn hình, khi đó bạn cần phải đăng ký lại các notification nếu có cho UIPopoverController này. Nếu không sau khi reshow thì  UIPopoverController không nhận notification nữa.
Ví dụ bạn muốn điều chỉnh lại kích thước của UIPopoverController mỗi khi bàn phím hiện ra chúng ta phải đăng ký nhận notification UIKeyboardWillShowNotification như sau:
//MyPopoverViewCtrl.h
@interface MyPopoverViewCtrl:UIPopoverController
-(void) reshow;
@end
//MyPopoverViewCtrl.m
@implementation MyPopoverViewCtrl
-(void) registerKeyboardEvent {
[ [NSNotificationCenter defaultCenter] addObserver:self select:@selector(doSomething:) name:UIKeyboardWillShowNotification object:nil];
}
-(void) unregisterKeyboardEvent{
[ [NSNotificationCenter defaultCenter] removeObserver:self  name:UIKeyboardWillShowNotification object:nil];
}
- (id)initWithContentViewController:(UIViewController *)viewController
self = [super initWithContentViewController:viewController];
if(self){
 [self registerKeyboardEvents];
}
return self;
}
-(void) dealloc{
[self unregisterKeyboardEvent];
[super dealloc];
}
-(void) reshow{
    [self unregisterKeyboardEvent];
   //do reshow
   [self registerKeyboardEvent];
}
-(void) doSomething:(NSNotification*)noti{
//Do what you want.
}
@end

21/12/2012

9 ỨNG DỤNG IN ẤN HÀNG ĐẦU TRÊN ANDROID

Hiện nay ở Việt Nam, điện thoại Android dần phổ biến. Một chiếc điện thoại Android thì không thể thiếu chiếc máy ảnh đi kèm. Khi chụp ảnh xong chúng ta thường tải lên các trang mạng xã hội như Facebook, Google Plus, ... Có bao giờ bạn muốn in những bức ảnh này ra máy in không? Làm cách nào để in?
Hiện nay theo F thì có các ứng dụng sau đây giúp bạn thực hiện được mong muốn này:

  1. StarPrint
    • Nội dung in: PDF, PS, văn bản trơn, nội dung trang Web, hình ảnh trong bộ sưu tập trên thiết bị, hình ảnh trên Instagram, SMS, sổ địa chỉ, thư điện tử.
    • Hỗ trợ in qua Bluetooth, Wi-Fi, USB.
    • Hỗ trợ hơn 3000 thiết bị in khác nhau của các hãng HP, Canon, Brothers, Epson, ...
  2. ePrint
    • Chỉ hỗ trợ các máy in Epson, Canon, HP.
    • Chỉ hỗ trợ Android 3.0 trở đi.
  3. Canon Easy PhotoPrint
    • Chỉ hỗ trợ máy in Canon
    • Hỗ trợ in PDF và hình tạo bởi "Canon equipment" 
  4. Epson iPrint (CyPria)
    • Chỉ hỗ trợ máy in Epson.
    • Hỗ trợ nhiều loại tập tin 
    • Có thể in từ Box, DropBox, Evernote và Google Docs.
  5. KODAK Document Print
    • Yêu cầu tài khoản "Google Cloud Print" và máy in không dây Kodak.
    • Hỗ trợ nhiều loại tập tin.
  6. Breezy-Print and Fax
    • Hỗ trợ cả iOS và Blackberry.
    • Yêu cầu "Breezy subscription".
  7. Office Max Print Center
    • Yêu cầu phải có "Office Max Network".
  8. Brother iPrint & Scan
    • Chỉ hỗ trợ máy in Brothers.
  9. HP ePrint Home & Biz
    • Chỉ hỗ trợ máy in HP. 

19/12/2012

nlctim version 2.0 release

Phiên bản 2.0 của nlctim được release vào 19/12/2012.
Phiên bản này tương thích với Yahoo! Messenger 11.5
Tải nlctim về tại http://nlctim.sf.net

09/12/2012

Student Visit Tour Document

Thời gian vừa qua Folami có cơ hội được trò chuyện với các bạn sinh viên HCMUT (cũng là các bạn đồng môn F). Nội dung chính là các bạn chuẩn bị gì để trở thành một nhà phát triển phần mềm C/C++ và một vài kinh nghiệm cho buổi phỏng vấn xin việc. Tất cả những vấn đề nêu ra đều xuất phát từ ý kiến cá nhân của F trong quá trình phỏng vấn các bạn sinh viên mới ra trường xin việc làm. Nếu có thông tin gì không đúng hay có gì muốn trao đổi với F thì đừng ngần ngại gửi email cho F.

06/12/2012

Hiển thị tập tin Freemind trong Blogger


  •  Tải visorFreemind.swf từ trang nhà của Freemind
  • Upload visorFreemind.swf lên một host miễn phí nào đó ví dụ http://www.000webhost.com. Giả sử URL của file visorFreemind.swf là http://www.example.com/visorFreemind.swf
  • Upload file Mindmap example.mm lên host tương tự như tập tin visorFreemind.swf. Giả sử URL của file này là  http://www.example.com/example.mm
  • Tạo bài viết mới trong blog của bạn chọn tab "HTML" và post nội dung bên dưới vào:
<div style="width: 100%;height:500px;">
<object data="http://www.example.com/visorFreemind.swf" height="100%" type="application/x-shockwave-flash" width="100%">
<param name="movie" value="http://www.example.com/visorFreemind.swf" />
<param name="quality" value="high" />
<param name="flashvars" value="initLoadFile=http://www.example.com/example.mm&amp;openUrl=_self&amp;startCollapsedToLevel=3&amp;maxNodeWidth=200&amp;mainNodeShape=elipse&amp;justMap=false&amp;defaultToolTipWordWrap=200&amp;offsetX=middle&amp;offsetY=middle&amp;buttonsPos=top&amp;min_alpha_buttons=20&amp;max_alpha_buttons=100&amp;scaleTooltips=false&amp;bgcolor=0xF8FBFC" />
</object>
</div>
Sau đây là một ví dụ:

05/12/2012

Những điểm mới trong XCode 4.5

Hiện nay XCode có phiên bản mới nhất là 4.5.2. So với phiên bản 4.5 thì các phiên bản 4.5.1 và 4.5.2 chủ yếu là để sửa các lỗi trong phiên bản 4.5. So với các phiên bản trước đó thì XCode 4.5 có những điểm nổi bật như sau:

  1. LLDB là trình gỡ rối mặc định thay cho GDB.
  2. Hỗ trợ OpenGL debugging & performance analysis.
  3. Auto layout.
  4. Object-C literal trong NSArray và NSDictionary.
  5. Hỗ trợ truy xuất bằng toán tử [].
  6. Hỗ trợ chuẩn C++11.
Trong các điểm này thì 4 và 5 là hai điểm hấp dẫn nhất:

  • NSNumber literals:
  // character literals.
  NSNumber *theLetterZ = @'Z';          // equivalent to [NSNumber numberWithChar:'Z']

  // integral literals.
  NSNumber *fortyTwo = @42;             // equivalent to [NSNumber numberWithInt:42]
  NSNumber *fortyTwoUnsigned = @42U;    // equivalent to [NSNumber numberWithUnsignedInt:42U]
  NSNumber *fortyTwoLong = @42L;        // equivalent to [NSNumber numberWithLong:42L]
  NSNumber *fortyTwoLongLong = @42LL;   // equivalent to [NSNumber numberWithLongLong:42LL]

  // floating point literals.
  NSNumber *piFloat = @3.141592654F;    // equivalent to [NSNumber numberWithFloat:3.141592654F]
  NSNumber *piDouble = @3.1415926535;   // equivalent to [NSNumber numberWithDouble:3.1415926535]
  // BOOL literals.
  NSNumber *yesNumber = @YES;           // equivalent to [NSNumber numberWithBool:YES]
  NSNumber *noNumber = @NO;             // equivalent to [NSNumber numberWithBool:NO]
 #ifdef __cplusplus
  NSNumber *trueNumber = @true;         // equivalent to [NSNumber numberWithBool:(BOOL)true]
  NSNumber *falseNumber = @false;       // equivalent to [NSNumber numberWithBool:(BOOL)false]
 #endif
Lưu ý:
    • Giá trị sau @ là một giá trị đơn, không chấp nhận biểu thức. Trong trường hợp cần đóng gói
      (boxing) cho một biểu thức thì sử dụng cú pháp:@(expression)
    • Đóng gói giá trị enum thì giá trị này chuyển sang kiểu của enum, nếu enum không khai báo kiểu
      thì kiều mặc định là số nguyên.
    • Đóng gói C string chuyển thành NSString với UTF8 encoding.
  • Container literals:
    • Array: NSArray*a = @[Danh sách các đối tượng ngăn cách nhau bằng dấu phẩy];
    • Dictionary: NSDictionary*b = @{ 1 danh sách các cặp @"key":object cách nhau bằng dấu phẩy}.
  • Object subscripting:
NSMutableArray *array = ...;
NSUInteger idx = ...;
id newObject = ...;
id oldObject = array[idx];
array[idx] = newObject;      // replace oldObject with newObject

NSMutableDictionary *dictionary = ...;
NSString *key = ...;
oldObject = dictionary[key];
dictionary[key] = newObject; // replace oldObject with newObject
  • Sử dụng #if __has_feature(objc_array_literals|objc_dictionary_literals|objc_subscripting) để kiểm tra chức năng này có hay không.

24/06/2012

Lập trình Qt cho Android

Nếu bạn đã có một chương trình Qt chạy khá tốt trên các nền tảng khác bây giờ bạn muốn chuyển nó qua Android mà bạn không muốn tốn nhiều công sức để viết lại từ đầu sử dụng Android SDK thì đây là bài viết phù hợp cho bạn.
Tôi cũng là một nhà phát triển phần mềm sử dụng Qt/QML. Tôi cũng có một mong muốn giống bạn. Tôi đã bắt đầu từ Android Lighthouse. Tuy nhiên gần đây tôi đã phát hiện ra Necessitas. Necessitas đã cung cấp cho người  dùng một bộ SDK khá hoàn chỉnh để phát triển chương trình Qt/QML cho Android. Necessitas sử dụng Android Lighthous, Qt Creator, Ministro. Tuy Necessitas chưa được ổn định nhưng đã phần nào đáp ứng nhu cầu của tôi.
Tôi đã thử phát triển chương trình QML và deploy trên Android phone. Chương trình chạy rất OK.

13/06/2012

Lần đầu tiên sử dụng dịch vụ nhờ thu hộ Séc

Nhớ lần đầu tiên tôi nhận Séc của GMI. Tôi không biết phải làm sao để sử dụng nó. Tôi lên mạng hỏi nhà thông thái Google. Thì ra tôi phải ra ngân hàng sử dụng dịch vụ thu hộ Séc. Gần chỗ tôi làm có phòng giao dịch của ngân hàng STB. Khi tôi đưa tờ Séc ra cô nhân viên xinh đẹp hỏi tôi có phải Séc du lịch không? Trời ơi tui biết Séc du lịch là cái gì tui chết liền ý. Tôi mới trả lời là mình không biết. Cô ấy chạy lại hỏi cấp trên một hồi và nói:
-Anh ơi cái này anh qua VCB ấy, bên đó họ mới thanh toán Séc quốc tế.
Tôi trở về mà lòng buồn buồn và tự hỏi sao mà phiền phức tiếp. Có được vài từ khoá qua cuộc trao đổi với cô tiếp tân của STB tôi quyết định hỏi bác Google lần nữa. Lần này tui hỏi bác ấy ngân hàng nào chấp nhận thanh toán. Bác ấy trả lời là BIDV. Sáng hôm sau tôi đến phòng giao dịch BIDV lấy số thứ tự và ngồi chờ. Đến lượt tui, tui đưa cái Séc ra, cô nhân viên BIDV lại lắc đầu lia lịa:
-Anh ui cái  này anh qua VCB kế bên nha, bên đó họ mới thanh toán Séc quốc tế.
Tôi đành phải qua phòng giao dịch VCB kế bên. Lần này không phải lấy số đâu nhé vì trưa rồi không còn ai nữa. Tôi đưa tờ Séc cho anh đẹp trai, anh ta lại lắc đầu nguầy nguậy:
-Anh ui cái này anh phải đến chi nhánh cơ. Ở TP.HCM thì anh đến CN Kỳ Đồng hay CN Bến Chương Dương.
Tôi không quên cảm ơn anh.
Hôm sau, tôi lên CN Kỳ Đồng vì chỗ này gần chỗ tôi. Tôi bắt số và ngồi chờ đến lượt. Cuối cùng cũng đến lượt tôi. Tôi đưa tờ Séc cho cho bank teller, cô ta nói giọng Huế ngọt lịm:
-Anh ui, cái này anh đến chỗ Bến Chương Dương nha, ở đó mới có bộ phận làm việc này.
Trong lòng bắt đầu chán nản nhưng tôi cũng cố lên Bến Chương Dương:
-Anh ui, cái địa chỉ trong Séc không giống trong CMND, địa chỉ này là địa chỉ tạm trú à. Vậy anh có đem sổ tạm trú không?
-Trời ơi sao tôi biết cái này phải đem sổ tạm trú chứ! Chị vui lòng cho tôi bổ sung khi đến nhận tiền không?
-Không được anh à! Vì sếp em duyệt nữa mà không có sổ tạm trú là không được duyệt rùi.
Tôi đành phải chạy về nhà để mượn sổ tạm trú. Khi quay lên tôi lại không đi đường cũ mà chạy lạc qua hầm chui Thủ Thiêm. Lần đầu tiên tôi chạy qua cái hầm này. Trời đất ơi cái hầm sao mà dài và qua hầm lại không có chỗ quay đầu xe. Cuối cùng cũng đến được VCB một lần nữa. Lần này mọi thứ suôn sẻ. Tiền thu từ Séc có thể tự động chuyển vào tài khoản.

02/06/2012

PHP: Phân biệt Android Phone và Android Tablet

Đầu tiên lấy thông tin UA từ server:
$userAgent = $_SERVER['HTTP_USER_AGENT'];
Nếu chuỗi này có chứa từ Android thì client device đang chạy Android OS:
if (stripos($userAgent, 'Android') !== false){
//Cần xác định Android Phone hay Android Tablet ở đây.
Không có một cách nào chính xác để phân biệt giữa Android Phone và Android Tablet (chưa kể một số web browser cho phép người dùng thiết lập UA). Tuy nhiên có một số mẹo sau:
  • Android 3.x chỉ sử dụng cho các Tablet.
  • Google khuyên các nhà sản xuất bỏ chữ 'Mobile' ra khỏi chuỗi UA.
  • Một số thiết bị Kindle Android lại có chữ Mobile trong UA nhưng nó lại không có chữ Silk.
if (stripos($userAgent, 'Android') !== false){
if (stripos($userAgent, 'Android 3') !== false || 
 stripos($userAgent, 'Tablet') !== false || 
stripos($userAgent, 'Mobile') === false || 
 stripos($userAgent, 'Silk') !== false )
  {
  //Android Tablet  
}else{
//Android Phone
}
}

12/05/2012

Tắt ARC trong XCode 4.2

Trong XCode 4.2, khi bạn tạo một dự án mới thì có một checkbox cho phép bạn chọn là dự án của bạn có dùng chức năng ARC (Automatic Reference Counting) hay không. Với chức năng này khi viết code bạn không phải quan tâm nhiều đến việc quản lý bộ nhớ. Bạn đã chọn sử dụng ARC. Tuy nhiên sau đó dự án của bạn phải sử dụng một thư viện của hãng thứ ba, thư viện này lại không sử dụng tính năng ARC. Do đó bạn đứng trước một lựa chọn vô cùng khó khăn: Sử dụng thư viện hay sử dụng ARC. Mình tin rằng bạn chọn sử dụng thư viện. Vậy làm sađâyo để tắt tính năng ARC cho dự án hiện tại đây? Bạn làm theo các bước sau đây:
  1. Chọn project file
  2. Chọn tab Build Settings, chọn tuỳ chọn Levels (mặc định là Combined)
  3. Có một ô dùng để tìm kiếm gần Combined, gõ vào từ Automatic
  4. Chọn nhóm Apple LLVM Compiler 3.0 – Language, hàng thứ hai trong nhóm này dùng để điều khiển ARC
  5. Chuyển "yes" sang "no" ở hàng này

11/05/2012

Hide navigation bar

Trong lập trình iOS sử dụng navigation controller đôi chúng ta muốn ẩn đi navigation bar chẳn hạn như ở view đầu tiên. Ở view nào chúng ta muốn tắt navigation bar chúng ta sử dụng đoạn code sau:

- (void) viewWillAppear:(BOOL)animated{
    [self.navigationController setNavigationBarHidden:YES animated:animated];
    [super viewWillAppear:animated];
}
- (void) viewWillDisappear:(BOOL)animated{
    [self.navigationController setNavigationBarHidden:NO animated:animated];
    [super viewWillDisappear:animated];
}

09/05/2012

Kiếm tiền qua mạng: Lập trình viên tự do

Nếu bạn là một lập trình viên, một chuyên viên thiết kế đồ hoạ giỏi thì việc chọn ở nhà làm một người làm nghề tự do (freelancer) cũng là một lựa chọn không tồi lắm, đôi khi còn sáng suốt nếu bạn là người yêu thích tự do nhưng không thích làm doanh nhân mở công ty riêng.
Để làm freelancer bạn phải chọn cho mình một nguồn công việc ổn định, nếu bạn là người quan hệ rộng có nhiều quan hệ thì quá tốt còn không bạn hãy chọn cho mình một website. Rất nhiều website dạng này:
Tôi đã từng làm cho vWorker.com. Đây là website rất tốt. Bạn chỉ cần đăng ký một tài khoản miễn phí. Sau đó sử dụng RSS reader để nhận liên kết công việc mới nhất được post trên website. Sau đó bạn vào đấu giá công việc phù hợp với bạn. Khi Employers chấp nhận bạn, bạn tiến hành công việc theo thảo thuận. Tiền lúc này đã được Employers chuyển vào tài khoản bên thứ 3. Khi bạn giao kết quả, Employers chấp nhận kết quả đó thì tiền sẽ chuyển từ bên thứ ba vào tài khoản của bạn trên vWorker.
Nếu có xảy ra tranh chấp thì bạn hãy nhờ các trọng tài Arbitrator phân xử.
Đến kỳ hạn thì vWorker sẽ chuyển tiền của bạn theo phương thức mà bạn chọn. Các phương thức gồm có:
  • Trả qua Western Union: vWorker gửi cho bạn mã chuyển tiền. Bạn chỉ cần ra chi nhánh Western Union gần nhất, đọc mã số trên để nhận tiền. Phương pháp này phí chuyển tiền khá cao.
  • Snail mail check: vWorker gửi séc cho bạn qua thư đến địa chỉ nhà bạn. Mình không dùng cách này.
  • Payoneer
  • Paypal: Cách này mình thấy tiện lợi nhất. vWorker chuyển tiền vào tài khoản Paypal của bạn. Bạn có thể chuyển tiền từ tài khoản Paypal vào tài khoản ngân hàng ở Việt Nam. Mỗi giao dịch hiện nay Paypal tính $5 và điểm cần lưu ý là tỉ lệ qui đổi tiền USD sang VND thường thấp hơn thị trường.
  • Skrill: Mình chưa thử cách này.
Cái khó ở vWorker là bạn phải có vài công việc thành công trong hồ sơ của bạn thì bạn mới dễ thắng trong đấu thầu công việc. Vậy các bạn mới thì khá khó khăn, bạn hãy bỏ giá thấp trong các công việc đầu để làm đẹp hồ sơ của mình nha. Khi đấu thầu bạn phải chuyên nghiệp, không nên ghi ngắn gọn là tôi có thể làm việc này mà nên ghi sao thuyết phuch được Employers chọn mình. Theo mình nên gửi prototype.
Chúc các bạn may mắn.
Bài kế tiếp mình sẽ viết về cách kiếm tiền qua mạng bằng "Lập website"


28/04/2012

Vua bánh mì (King Of Baking, Kim Tak Goo)



 

  • Đạo diễn: Han Joon Seo
  • Diễn viên: Yoon Si Yoon, Joo Woo, Lee Young Ah, Jun Gwang Ryul, Jun In Hwa, Jun Mi Sun, Oh Jae Moo, Shin Dong Woo
  • Thể loại:Tình cảm, hài hước
  • Sản xuất: KBS
  • Quốc gia: Hàn Quốc
  • Thời lượng: 30 Tập
  • Năm phát hành: 2010
Mới vừa xem xong bộ phim Vua bánh mì, trong đầu còn đọng lại vài điều để chia sẻ cùng mọi người:
  • Thích nhất là mỗi lúc gặp khó khăn, chùng bước anh chàng Kim Tak Goo lại tự gọi tên mình và nói "Phải là chính mình". Đúng vậy phải là chính mình, biết rõ mình là ai, thích điều gì, đam mê điều gì, mạnh ở đâu và yếu chỗ nào thì nhất định chuyện gì, khó đến đâu cũng làm được. 
  • Đoạn xúc động nhất là lúc chị cả Goo Ja Kyung ôm chầm hai cậu em trai Kim Tak Goo  và Goo Ma Joon với niềm hạnh phúc, xúc động và lòng  biết ơn trào lên ở khoé mắt. Một cảnh đẹp của sự đoàn kết của tình anh em. Nếu biết đoàn kết và thương yêu nhau của anh chị em trong một nhà thì không gì hạnh phúc bằng.
  • Luật nhân quả:  Seo In Sook là con dâu sống không tốt với mẹ chồng nên sau này cô con dâu Shin Yoo Kyung cũng lấy cùng thái độ để đối đãi với bà.
  • Xem phim chắc ai cũng thấy đáng ghét nhất là Goo Ma Joon nhưng thật ra cậu ấy thật đáng thương. Cậu ấy là một con người lương thiện nhưng vì sự tác động của Han Seung Jae và mẹ mình nên anh đi từ sai lầm này đến sai lầm khác nhưng cuối cùng cái thiện trong con người anh ta cũng được bộc lộ ở cuối phim khi anh đã vì nghĩa diệt thân tự tay đưa Han Seung Jae (người mà theo anh là cha ruột của mình) vào còng vì đây là cách duy nhất để cứu ông. 
  • Con trai nhờ đức mẹ: Đây là câu nói của ông bà xưa. Trong câu chuyện này cũng thể hiện phần nào cái ý này qua hai nhật vật Kim Tak Goo và Goo Ma Joon.
  • Kết thúc phim với triết lý sống mỗi người chỉ sống thật sự hạnh phúc khi được làm những gì mình yêu thích. Hãy làm nó với tất cả niềm đam mê cháy bỏng, bạn sẽ thành công.
  • Hơi hụt hẫng một tí khi cảnh Hwang Mi Sun mặc áo cô dâu cùng chàng rễ Kim Tak Goo không xuất hiện. 

27/04/2012

Kiếm tiền qua mạng:Trả lời bảng khảo sát

Bài viết này nằm trong loạt bài viết  "Kiếm tiền qua mạng". Trong loạt bài viết này tôi sẽ lần lượt chia sẻ kinh nghiệm thực tế của tôi về những cách kiếm tiền qua mạng mà tôi đã từng làm. Nếu bạn không thích đi làm ở một công ty mà muốn tự do, tự tại thì mạng máy tính là một kênh kiếm tiền không thể bỏ qua. Có rất nhiều cách kiếm tiền từ mạng, sau đây là một số cách mà tôi đã làm:
  • Trả lời bảng khảo sát
  • Lập trình viên tự do
  • Lập website (forum, blog, directory) bán quảng cáo, link, logo, ...
  •  Kinh doanh bất động sản mạng ( tên miền ý mà).
  • Post liên kết
Sau đây tôi xin giới thiệu phương pháp đầu tiên: Trả lời bảng khảo sát.
  1. Để tham gia được phương pháp này điều cần thiết là bạn phải có một tài khoản email. Bạn có xin một tài khoản email miễn phí từ Yahoo, Google, Gawab, Hotmail, ... một cách dễ dàng.
  2. Đăng ký tài khoản tại trang https://www.globaltestmarket.com
  3. Trả lời tất cả các Profile Surveys vì nó sẽ giúp cho GlobalTestMarket hiểu rõ hơn về bạn.
  4. Khi có một bảng khảo sát phù hợp với bạn, GlobalTestMarket sẽ gửi đến địa chỉ email của bạn. Mỗi một bảng khảo sát có điểm từ 5-60 điểm, 5-80 điểm.
  5. Tham gia trả lời bảng khảo sát, tuỳ câu trả lời của bạn mà số điểm bạn nhận sẽ khác nhau.
  6. Khi tài khoản của bạn đạt ít nhất 1000 điểm, bạn có thể yêu cầu Redeem trong trang Rewards. Khi đó GlobalTestMarket sẽ yêu cầu bạn xác nhận lại địa chỉ của bạn để GlobalTestMarket gửi tiền cho bạn (Thời gian nhận là từ 4-8 tuần). 1000 điểm tương ứng $50.
Bài kế tiếp tôi sẽ chia sẻ về việc kiếm tiền bằng làm "Lập trình viên tự do"