Home
About
Search
🌐
English Română
  • Adobe AIR

    Citește postarea în română

    Nov 6, 2009 Adobe AIR JavaScript soap Webkit zend framework
    Share on:

    Last week I was supposed to create a little project. Requirements were short: interoperability.Given the fact that I’ve never used Adobe AIR before, I thought it was a good opportunity to try it.

    The result was a small project management app. For the server-size I’ve used PHP + SOAP + Zend Framework, and for the client I’ve used Adobe AIR with JavaScript.

    I’ve created the server in a few lines:

     1<?php
     2// autoload class for Zend Framework
     3include 'Zend/Loader/Autoloader.php';
     4
     5// class that deals with SOAP requests
     6include 'SOAP.class.php';
     7
     8// initialize autloader
     9Zend_Loader_Autoloader::getInstance();
    10
    11// if it's a request for the WSDL descriptor file
    12if(isset($_GET['wsdl'])) {
    13 $autodiscover = new Zend_Soap_AutoDiscover();
    14 $autodiscover->setClass('test');
    15 $autodiscover->handle();
    16// if it's a SOAP request
    17} else {
    18 $soap = new Zend_Soap_Server("http://localhost/soap/index.php?wsdl");
    19 $soap->setClass('test');
    20 $soap->handle();
    21}
    22
    23?>
    

    The descriptor is build automatically using PHP Documenter type comments from the class that handles SOAP requests, if this case it’s named “test”.

    This was the easy part so I’ve moved on to the Adobe AIR client following this simple steps:

    • Download and install Aptana Studio
    • Install Adobe AIR plug-in
    • New project -> Adobe AIR
    • and voila! Coding can begin!

    Adobe AIR is using for a JavaScript engine Webkit. Sounds familiar? Webkit is used by Safari and Google Chrome. So the JavaScript code should only be compatible with Webkit!

    Of course there is a “but” and a plus. The “but” is that there are some restrictions, for instance “eval” can only be used to decode JSON, and the text introduced directly in an element (as text) can not be executed:

    1div.innerHTML = "<a onclick=\"alert('ceva')\" href=\"#\">click</a>";
    

    This link will get to the element by will not run anything on “onclick” because the parameter was send as text.

    This was a pretty big disadvantage for me, but I’ve managed to figure out an alternative by building HTML elements using DOM and adding events using addEventListener.

    Briefly Adobe AIR is using this formula:

    1Adobe AIR = (Webkit)Web Development - security + air framework.
    

    It seems very easy for a Web Developer to develop desktop apps with Adobe AIR.

    Of course is not very fast and it’s not looking like a good idea for complex apps. But if your thinking about medium and small apps, if I had to choose between Adobe AIR and PHP GTK for instance, the first option seems a lot more viable and easy to use!

    In the end the project was ready in less then 3 days and the graphics were gorgeous! It didn’t even look like it was build using only HTML and JavaScript!

  • Generating .CHM manual for Zend Framework using HTML Help Workshop

    Citește postarea în română

    Aug 9, 2009 chm HTML Help Workshop zend framework
    Share on:

    If your like me you prefer manuals in CHM format.

    Unfortunately Zend Framework manual is only in .pdf and a little less obvious in HTML format.

    Fortunately generating a format CHM manual is easy(really, it is).

    The steps are:

    1. Download and install HTML Help Workshop.

    2. Download the Zend Framework manual in HTML format, the link is in bottom right, not very obvious I believe.

    3. Open HTML Help Workshop.

    4. File->Open and from the folder where the manual files are open htmlhelp.hhp

    5. File->Complile

    Done!

    The compiled CHM manual is just few steps away!

  • JavaScript Games

    Citește postarea în română

    Aug 2, 2009 browser CSS HTML JavaScript
    Share on:

    Today the JavaScript Games section is officially launched! The games have been recently created, after the model of classic games.

    I’ve started the first game to show a friend that it is possible to build this kind of apps with JavaScript. And this is one of the main ideas of the section: interactivity in the browser using only HTML, CSS and of course JavaScript!

    Today I make them public because is a shame to not give others the chance to waste time playing :).

    The games should work cross-browser, they don’t have HTML 5 or other stuff that can lead to incompatibility. They shall prove the power of JavaScript, without any other sophisticated tools.

    Many games are not well finished, but I hope that with time I’ll resolve the issues, add new features and of course new games. For suggestions and issues, please send an e-mail to claudiu@claudiupersoiu.ro.

    Have fun!

  • Good bye YSlow, welcome Page Speed

    Citește postarea în română

    Jul 17, 2009 Firefox Google PageSpeed Yahoo YSlow
    Share on:

    After more than a year of using YSlow, apparently with the arrival of FireFox 3.5 this plug-in is no longer supported.

    YSlow is a very interesting tool created by Steve Souders, who wrote High Performance Web Sites, and the new Even Faster Web Sites.

    The plug-in, which used the FireBug extension, was a practical tool to analyze performance by the 14 rules described in the book, giving grades to pages at loading. A very useful tool, both for designers and front end developers.

    But with the launch of FireFox 3.5, which brings many improvements in speed, YSlow becames incompatible. After what seemed like Yahoo! will totally give up the project a new version appeared. Unfortunately this version is not exactly functional. I do not know if is my FireBug version or just the update was made to shut the mouth of those who complain about the incompatibility.

    Google has not launched any time this infra. After launching Google Speed, it seems that not late after that, appeared a substitute for YSlow, named Google PageSpeed.

    PageSpeed structure is similar to YSlow, anyway optimization rules are the same for everybody, it’s just how they are approached.

    What is more important PageSpeed is compatible with FireFox 3.5.

    An interesting fact to know is that Steve Souders now works for Google, maybe this is one of the reasons for which these rival tools, produced by two Internet giants have reached these state.

  • The site becomes bilingual

    Citește postarea în română

    Jul 11, 2009
    Share on:

    Starting today the website is becoming bilingual! Besides Romanian, I’ll post in English to.

    To use two languages in the blog  I’m using the LanguageSwitcher plug-in, a little modified so all users from Romania and Republica Moldova will be able to view the romanian version, regardless of browser settings.

    I hope my English will be excused.

    • ««
    • «
    • 6
    • 7
    • 8
    • 9
    • 10
    • »
    • »»

Claudiu Perșoiu

Programming, technology and more
Read More

Recent Posts

  • Adding a slider to Tasmota using BerryScript
  • The future proof project
  • Docker inside wsl2
  • Moving away from Wordpress
  • Custom path for Composer cache
  • Magento2 and the ugly truth
  • A bit of PHP, Go, FFI and holiday spirit
  • How to make use of the Xiaomi Air Conditioning Companion in Home Assistant in only 20 easy steps!

PHP 49 MISCELLANEOUS 46 JAVASCRIPT 14 MAGENTO 7 MYSQL 7 BROWSERS 6 DESIGN PATTERNS 5 HOME AUTOMATION 2 LINUX-UNIX 2 WEB STUFF 2 GO 1

PHP 35 JAVASCRIPT 15 PHP5.3 11 MAGENTO 7 PHP6 7 MYSQL 6 PHP5.4 6 ZCE 6 CERTIFICARE 5 CERTIFICATION 5 CLOSURES 4 DESIGN PATTERNS 4 HACK 4 ANDROID 3
All tags
3D1 ADOBE AIR2 ANDROID3 ANGULAR1 ANONYMOUS FUNCTIONS3 BERRYSCRIPT1 BOOK1 BROWSER2 CARTE1 CERTIFICARE5 CERTIFICATION5 CERTIFIED1 CERTIFIED DEVELOPER1 CHALLENGE1 CHM1 CLASS1 CLI2 CLOSURES4 CODE QUALITY1 CODEIGNITER3 COFFEESCRIPT1 COLLECTIONS1 COMPOSER1 CSS1 DEBUG1 DESIGN PATTERNS4 DEVELOPER1 DEVELOPMENT TIME1 DOCKER2 DOCKER-COMPOSE1 DOUGLAS CROCKFORD2 ELEPHPANT2 FACEBOOK2 FFI1 FINALLY1 FIREFOX3 GAMES1 GENERATOR1 GO1 GOOGLE1 GOOGLE CHROME1 GOOGLE MAPS1 HACK4 HOMEASSISTANT2 HTML2 HTML HELP WORKSHOP1 HTML51 HUG1 HUGO1 INFORMATION_SCHEMA1 INI1 INTERNET EXPLORER3 IPV41 IPV61 ITERATOR2 JAVASCRIPT15 JQUERY1 LAMBDA1 LINUX1 MAGENTO7 MAGENTO22 MAP1 MINESWEEPER1 MOTIVATION1 MYSQL6 NGINX1 NODE.JS2 NOSQL1 OBSERVER3 OBSERVER PATTERN1 OOP1 OPERA1 OPTIMIZATION1 ORACLE1 PAGESPEED1 PAIR1 PARSE_INI_FILE1 PHONEGAP2 PHP35 PHP ELEPHANT2 PHP FOR ANDROID1 PHP-GTK1 PHP42 PHP53 PHP5.311 PHP5.46 PHP5.53 PHP5.61 PHP67 PHP7.41 PROGRAMMING1 REVIEW1 ROMANIAN STEMMER2 SAFARY1 SCALAR TYPE HINTING1 SCHEME1 SET1 SHOPPING CART PRICE RULE1 SINGLETON1 SOAP1 SPL2 SQLITE1 SSH1 STACK TRACE1 STDERR1 STDIN1 STDOUT1 SUN1 SYMFONY2 TASMOTA1 TEST TO SPEECH1 TITANIUM2 TRAITS1 TTS1 UBUNTU1 UNICODE2 UTF-82 VECTOR1 WEBKIT1 WINBINDER1 WINDOWS2 WORDPRESS1 WSL21 YAHOO3 YAHOO MAPS1 YAHOO OPEN HACK1 YSLOW1 YUI1 ZCE6 ZCE5.31 ZEND3 ZEND FRAMEWORK3
[A~Z][0~9]

Copyright © 2008 - 2024 CLAUDIU PERȘOIU'S BLOG. All Rights Reserved