Monday, 31 October 2011

Create Windows logo without using image and javascript only use CSS.

HTML

<div id="windows">
    <div class="canvas">
        <div class="icon">
            <div class="window1">
                <div class="window-e1"></div>
                <div class="window-e2 shadow1"></div>
                <div class="window-e2 shadow2"></div>
                <div class="window-e2"></div>
                <div class="window-e3"></div>
                <div class="window-e4 shadow3"></div>
                <div class="window-e4"></div>
            </div>
            <div class="window4">
                <div class="window-e1 shadow3"></div>
                <div class="window-e1"></div>
                <div class="window-e2 shadow1"></div>
                <div class="window-e2 shadow2"></div>
                <div class="window-e2"></div>
                <div class="window-e3"></div>

                <div class="window-e4"></div>
            </div>
            <div class="window3">
                <div class="window-e1"></div>
                <div class="window-e2 shadow1"></div>
                <div class="window-e2 shadow2"></div>
                <div class="window-e2"></div>
                <div class="window-e3"></div>
                <div class="window-e4 shadow3"></div>
                <div class="window-e4"></div>
            </div>
            <div class="window2">
                <div class="window-e1 shadow3"></div>
                <div class="window-e1"></div>
                <div class="window-e2 shadow1"></div>
                <div class="window-e2 shadow2"></div>
                <div class="window-e2"></div>
                <div class="window-e3"></div>
                <div class="window-e4"></div>
            </div>
            <div class="glow"></div>
            <div class="registered">®</div>
        </div>
    </div>
</div>
 

CSS : 


.canvas { 
    border-radius: 5px;
    box-shadow: 0 1px 0 rgba(250,250,250,0.2) inset, 0 2px 2px RGBA(0,0,0,0.5);
    height: 300px;
    overflow: hidden;
    position: relative;
    text-indent:-9999px;
    width: 530px;
    z-index: 10;
}
.icon, .icon * {
    position: absolute;
}#windows .canvas { 
    background: #fff;
}
#windows .icon { 
    left:193px; 
    position: absolute; 
    top:20px;
    -moz-transform: rotate(16deg);
    -webkit-transform: rotate(16deg);
    transform: rotate(16deg);
}
.window-e1,
.window2,
.window3,
.window4 { 
    position:absolute;
}
.window-e1 { 
    border-radius:100px/67px;
    clip: rect(0px 77px 67px 0);
    height: 67px;
    left: 9px;
    position: absolute;
    top: 11px;
    width:102px;
}
.window-e2 {
    height: 85px;
    left: 0;
    position: absolute;
    top:27px;
    -moz-transform:skewy(-30deg);
    -webkit-transform:skewy(-30deg);
    transform:skewy(-30deg);
    width:25px;
}
.window-e3 { 
    height: 41px;
    left: 24px;
    position: absolute;
    top: 64px;
    width: 62px;
}
.window-e4 { 
    background: #fff;
    opacity:1;
    border-radius:100px/67px;
    clip:rect(0 77px 12px 16px);
    height: 67px;
    left: 9px;
    position: absolute;
    top: 96px;
    width:100px;
}
.window1 { 
    left:0;
    position: absolute;
    top:0;
}
.window1 .window-e1,
.window1 .window-e2,
.window1 .window-e3 { 
    background: #d53407;
}
.window2 {
    left: 183px;
    position:absolute;
    -moz-transform: rotate(180deg);
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
    top: 119px;
}
.window2 .window-e1,
.window2 .window-e2,
.window2 .window-e3 { 
    background: #7dae1c;
}
.window3 { 
    left: 0;
    position: absolute;
    top:95px;
}
.window3 .window-e1,
.window3 .window-e2,
.window3 .window-e3 { 
    background: #3576ac;
}
.window4 {
    left: 183px;
    position:absolute;
    -moz-transform: rotate(180deg);
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
    top: 214px;
}
.window4 .window-e1,
.window4 .window-e2,
.window4 .window-e3 { 
    background: #fac112;
}
#windows .glow {
    background: -moz-radial-gradient(50% 50%, circle, rgba(255,255,255,0.7),rgba(255,255,255,0));
    background: -webkit-gradient(radial,50% 50%,20,50% 50%,100,from(rgba(255,255,255,0.7)),to(rgba(255,255,255,0)));
    height: 214px;
    position: absolute;
    width:182px;
}
#windows .registered {
    left:190px;
    position: absolute;
    -moz-transform: rotate(-16deg);
    -webkit-transform: rotate(-16deg);
    transform: rotate(-16deg);
    top:160px;
}
#windows .shadow1,
#windows .shadow2,
#windows .shadow3 { 
    background: #ccc;
}
.window1 .window-e4,
.window3 .window-e4 { 
    top:101px;
}
.window1 .shadow1,
.window3 .shadow1 {
    left: 65px;
    clip: rect(0px 30px 94px 21px);
    -moz-transform: skewy(30deg);
    -webkit-transform: skewy(30deg);
    transform: skewy(30deg);
    top: 16px;
}
.window1 .shadow2,
.window3 .shadow2 { 
    clip:rect(50px 40px 90px 5px);
    top:30px;
    width:32px;
}
.window1 .shadow3,
.window3 .shadow3 {
    clip: rect(0 77px 12px 16px);
    top:96px;
}
.window2 .shadow1,
.window4 .shadow1 {
    clip:rect(0px 10px 90px 5px);
    left: -10px; top: 28px;
}
.window2 .shadow2,
.window4 .shadow2 { 
    clip:rect(70px 40px 90px 5px);
    left:-6px;
    top:-44px;
}
.window2 .shadow3,
.window4 .shadow3 {
    clip:rect(0 73px 22px 0px);
    left:9px;
    top:6px;
}

Create BP logo without using image and javascript only use CSS.

CSS Magic:

HTML

<div id="bp">
    <div class="canvas">
        <div class="icon">
            <div class="circle1">
                <div class="leaf"><div class="leaf"><div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"></div> </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> </div>
            </div>
            <div class="circle2">
                <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"> <div class="leaf"></div> </div> </div> </div> </div></div> </div> </div> </div> </div> </div></div> </div></div> </div> </div> </div> </div>
            </div>
            <div class="circle3">
                <div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div> </div></div></div>   
            </div>
            <div class="circle4">
                <div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"><div class="leaf"></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div> </div></div></div>
            </div>
        </div>
    </div>
</div>
 
 
CSS : 

.canvas { 
    border-radius: 5px;
    box-shadow: 0 1px 0 rgba(250,250,250,0.2) inset, 0 2px 2px RGBA(0,0,0,0.5);
    height: 300px;
    overflow: hidden;
    position: relative;
    text-indent:-9999px;
    width: 530px;
    z-index: 10;
}
.icon, .icon * {
    position: absolute;
}#bp .canvas { 
    background: #f9f7e3;
}
#bp .icon {
    height: 200px;
    left:150px;
    position: absolute;
    top:50px;
    width: 200px;
}
#bp .circle1 {
    left: 69px;
    position: absolute;
    top:83px;
}
#bp .leaf {
    border-radius:40px/100px;
    bottom:0;
    height: 100px;
    left:24px;
    position: absolute;
    -moz-transform:rotate(20deg);
    -webkit-transform:rotate(20deg);
    transform:rotate(20deg);
    width:40px;
}
#bp .leaf:before,
#bp .leaf:after {
    background: rgba(0,158,1,1);
    border-radius:137px/196px;
    clip:rect(15px 21px 127px 0px);
    content: "#";
    display: block;
    height: 141px;
    position: absolute;
    width: 98px;
    
}
#bp .leaf:before { 
    left:11px;
    top:5px;
}
#bp .leaf:after {
    left:-47px;
    top:5px;
    -moz-transform:rotate(180deg);
    -webkit-transform:rotate(180deg);
    transform:rotate(180deg);
}
#bp .circle2 {
    left: 77px;
    position: absolute;
    top: 82px;
    -moz-transform:rotate(10deg) scale(0.82);
    -webkit-transform:rotate(10deg) scale(0.82);
    transform:rotate(10deg) scale(0.82);
}
#bp .circle2 .leaf:before,
#bp .circle2 .leaf:after {
    background: rgba(128,195,0,1);
    clip:rect(13px 18px 134px 0px);
}
#bp .circle2 .leaf:before {
    left:14px;
}
#bp .circle2 .leaf:after {
    left:-50px;
}
#bp .circle3 {
    left: 80px;
    position: absolute;
    top: 90px;
    -moz-transform: scale(0.63);
    -webkit-transform: scale(0.63);
    transform: scale(0.63);
}
#bp .circle3 .leaf:before,
#bp .circle3 .leaf:after {
    background:rgba(255,240,1,1);
}
#bp .circle3 .leaf:before {
    clip:rect(13px 14px 133px 0px);
    left:18px;
}
#bp .circle3 .leaf:after {
    clip:rect(14px 14px 134px 0px);
    left:-54px;
}
#bp .circle4 {
    left: 87.5px;
    position: absolute;
    top: 90.5px;
    -moz-transform:rotate(10deg) scale(0.47);
    -webkit-transform:rotate(10deg) scale(0.47);
    transform:rotate(10deg) scale(0.47);
}
#bp .circle4 .leaf:before,
#bp .circle4 .leaf:after {
    background: rgba(255,255,255,1);
    clip:rect(13px 10px 134px 0px);
}
#bp .circle4 .leaf:before {
    left:22px;
}
#bp .circle4 .leaf:after {
    left:-58px;
} 

Simple iOS 5 UI Design Tutorial Using Storyboard in XCode 4

Background Info (Not Necessary Reading): I read a 500 page book on Objective-C on Saturday and so I thought I was ready to start programming iPhone apps, so then I looked at a ton of books and tried to do the step-by-step tutorials but none of them made any sense since Apple has updated all of their development tools and there are a lot of new features that have made things in the past irrelevant. For example, XIB files were not automatically generated in the newest version of XCode, so it was a struggle to get even a simple program running. I didn't even know how to design a user interface, so being confused I naturally Googled the file in XCode that I didn't know what is was (storyboard) and I saw that it was Apple's new way to design user interfaces. 

Background Info (Required): Interface builder is a user interface design tool in XCode 4 where you can drag and drop objects from the side bar, and have them saved in a XIB (pronounced "zib") or a NIB file. A XIB file is an XML representation of your objects and their instance variables, and it is compiled into a NIB file when your application is built. In the past, when creating a new view you would have to create a new XIB file for each view. This had become quite cumbersome since very complex applications have lots of different views and it is hard envisioning transitions from each view to the next, so Apple made a very big improvement in the user interface design process by introducingStoryboarding. 

From Apple's Website:

     "Discover how Xcode's Interface Builder support for Storyboarding in iOS 5 makes designing your iOS apps so much easier. Storyboarding allows you to graphically arrange all your views within a single design canvas, where you can then define the app's logical flow, and even assign transition animations."

A Picture Is More Informative:


Source: Apple XCode 4


Goal: This tutorial will show you how to create a simple two-view application that switches between both views with a button, created using Storyboard in XCode 4. 

Note: It's good practice to push every button/toolbar/panel in a new program that you are getting to know. In most cases you really can't "break" anything. 

Note: A lot of the tutorials just confused me when they were explaining what everything means, so I just left that out. 



Tutorial








1. Open XCode 4 and create a new Single View Application called "iPhone_Tutorial_One" and create the repository. 




2. Once you reach the main window in XCode 4 click MainStoryBoard.storyboard.








3. XCode automatically generates a single view and now drag and drop a View Controller from the panel on the right. 
(Note: From the toolbar select View > Navigators > Hide Navigator to make Interface Builder use the whole main window.)



4. Drag a Label object from the right panel and double click to type "View One" or "View Two" text in each label. You can resize the label by clicking and pulling, and you can adjust the text size by adjusting the default size in the right panel. 



5. Now drag and drop two Round Rect Button(s) and double click to add the text "Info" on one button, and "Switch View" on the other. Repeat.



Note: When you select an object in a view and then CONTROL + CLICK + DRAG you should see a blue line appear. 

Note/Common Error: The direction you drag to and from matters i.e. left -> right is not equivalent to right -> left, i.e. object1 -> object2 is not equal to object2 -> object1.



6. Click one of the Switch View button so it is highlighted like below, then holding control then click the Switch View button and drag from the button until the blue line touches the other view. A black pop-up box will come up and select performSequeWithIdentifier:sender. Repeat for the other button.



 7. Go to File > New > New File and create a new UIViewController subclass file calledSecondViewController






8. Select the second view and then in the right panel click the drop down menu under the Custom Classtitle bar and change the Class to SecondViewController.


9. Edit the iPhone_Tutorial_OneViewController.h, iPhone_Tutorial_OneViewController.m, SecondViewController.h, and SecondViewController.m files. 


 (a) Your file should match this file exactly. 




(b) Add the code marked below.  





(c) Your file should match this file exactly. 




(d) Add the code marked below.  











10. Select the Info button on the view labeled View One and CONTROL + CLICK + DRAG from the button to the iPhone Tutorial One View Controller in the left panel and a pop-up menu will prompt you and selectpageInfo. Repeat for the other Info button and then connect it to the Second View Controller.










11. The program is all finished. Now you can click Run and the program should build and run.