반응형
반응형

영업은 고객의 거절에서 시작된다. 거절도 영업의 과정이다.
이걸 깨달으니 거절에 대한 두려움이 사라졌다.
우리는 상대로부터 거절당할 것이란 두려움 때문에 말을 못 건다.
그런 두려움이 없으니 자신감이 생길 수 밖에 없다.
- 예영숙 삼성생명 명예전무 (11년 보험왕)

 

예영숙 전무는 말합니다.
“파는 사람이 고객을 잡았다고 기뻐할 때
고객은 그 순간부터 떠날 준비를 한다.
고객을 붙잡기 위해서는
떠나려는 애인을 붙잡는 노력을 하듯이 해야 한다.”라고.
두려움은 당연히 필요합니다.
다만 우리가 가져야 할 두려움은
새로운 도전에 대한 두려움이 아닌,
너무 잘되고 있는 것에 대한 두려움이어야 합니다.

반응형
반응형

'제로'에 있을 때


여러분의 마음이
제로에 있을 때 창조가 일어납니다.
그것을 '영감을 얻는다'라고 합니다.
'신성한 지혜'는 모든 영감이 나오는 원천인데
그것은 저기 어디 밖에 있는 것이 아닙니다.
찾으러 다닐 필요가 없습니다.
찾으러 다니지 마세요.
이미 여러분 안에 있습니다!


- 조 바이텔 외《호오포노포노의 비밀》중에서 -


* '제로'는
무(無)의 상태를 뜻합니다.
100% 비워낸 '빈 잔'의 모습이기도 하고
100% 내려놓은 '빈 손'의 모습이기도 합니다.
그러나 놀라운 것은 바로 그 제로의 순간이
새로운 창조의 시작점이라는 사실입니다.
답은 내안에 있습니다. 내가 나를 비워
스스로 제로 상태로 만드는 것입니다.
그때 받는 하늘의 선물이
'영감'입니다.



반응형

'생활의 발견 > 아침편지' 카테고리의 다른 글

소리  (0) 2013.10.04
좋은 일은 빨리, 나쁜 일은 천천히  (0) 2013.10.03
  (0) 2013.10.01
다시 태어난다. 단식의 힘  (0) 2013.09.30
얻음과 잃음  (0) 2013.09.28
반응형

 

 

 

 

 

 

 

 

 

 

나는 현명한 외면보다는 열정적인 실책을 더 좋아한다. - 아나톨 프랑스 -

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

.

반응형
반응형

Animated Border Menus

A tutorial on how to create a off-canvas icon navigation with an animated border effect. The menu effect is inspired by CreativeDash's bounce menu for mobile apps.

 

DEMO : http://tympanus.net/Tutorials/AnimatedBorderMenus/ 

AnimatedBorderMenus

View demo Download source

The other day I saw a really nice concept of a menu on the UI8 site. CreativeDash implemented that gorgeous concept and I instantly had some ideas for more effects involving border transitions but also with the desktop in mind. So today I want to show you how to create something like that and provide some more inspirational examples.

In this tutorial we will be going through demo 2 where the menu icon is in the top left corner and the border is thickest on the left side.

Please note that we’ll be using transitions and animation on pseudo-elements which won’t work in some browsers (e.g. Safari and Mobile Safari).

So, let’s get started!

The Markup

The HTML structure for our menu will consist of a nav element that will contain a trigger anchor and an unordered list with the menu items which will consist of icons:

1
2
3
4
5
6
7
8
9
10
<nav id="bt-menu" class="bt-menu">
<a href="#" class="bt-menu-trigger"><span>Menu</span></a>
<ul>
<li><a href="#" class="bt-icon icon-zoom">Zoom</a></li>
<li><a href="#" class="bt-icon icon-refresh">Refresh</a></li>
<li><a href="#" class="bt-icon icon-lock">Lock</a></li>
<li><a href="#" class="bt-icon icon-speaker">Sound</a></li>
<li><a href="#" class="bt-icon icon-star">Favorite</a></li>
</ul>
</nav>

Let’s style this.

AnimatedBorderMenu01

The CSS

Note that the CSS will not contain any vendor prefixes, but you will find them in the files.
Let’s use the border-box box-sizing:

1
2
3
4
5
*,
*:after,
*::before {
box-sizing: border-box;
}

And let’s set some styles for the body and the main container:

1
2
3
4
5
6
7
body {
background: #04a466;
}
.container {
padding: 80px;
}

The padding will help providing some space around our content so that when the border appears, we guarantee that there is enough space around.

The main menu element will have position fixed so that, no matter where we are in the page, the border is always around the viewport. We set an initial border style which we will transition to a bigger border. Setting the initial height to 0 will make sure that the menu does not cover anything initially. The “backward” or closing height transition will have a delay of 0.3s:

1
2
3
4
5
6
7
8
9
10
11
12
.bt-menu {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 0;
border-width: 0px;
border-style: solid;
border-color: #333;
background-color: rgba(0,0,0,0);
transition: border-width 0.3s, background-color 0.3s, height 0s 0.3s;
}

When we open the menu, we’ll set the height to 100% (but we won’t transition that property) and the border will animate to 90px on the left side and 30px on all the other sides. The background color will be semi-transparent using an RGBA value. This will server as out overlay color:

1
2
3
4
5
6
.bt-menu.bt-menu-open {
height: 100%;
border-width: 30px 30px 30px 90px;
background-color: rgba(0,0,0,0.3);
transition: border-width 0.3s, background-color 0.3s;
}

Now we have to use a little trick. We will add another element using JavaScript which will server as a dummy container covering the whole page except the border. This will allow us to distinguish where we are clicking in order to close the whole thing. We don’t want the menu to close when clicking on the border but only when clicking in the space between.

1
2
3
4
.bt-overlay {
position: absolute;
width: 100%;
}

When we open the menu, this element will have full height:

1
2
3
.bt-menu-open .bt-overlay {
height: 100%;
}

Let’s style that little trigger element. We’ll give it a fixed position and we’ll show it in the top left corner of the page:

1
2
3
4
5
6
7
8
9
.bt-menu-trigger {
position: fixed;
top: 15px;
left: 20px;
display: block;
width: 50px;
height: 50px;
cursor: pointer;
}

The trigger anchor itself will serve as a container and the span will be the middle line of our hamburger menu icon. So we position it in the middle by setting the top to 50% and giving it a negative top margin of half of its height:

1
2
3
4
5
6
7
8
9
10
11
12
13
.bt-menu-trigger span {
position: absolute;
top: 50%;
left: 0;
display: block;
width: 100%;
height: 4px;
margin-top: -2px;
background-color: #fff;
font-size: 0px;
user-select: none;
transition: background-color 0.3s;
}

When opening the menu, we will make a cross out of the icon. The other two lines will be created by pseudo-elements and when the menu is open, the middle line will disappear:

1
2
3
.bt-menu-open .bt-menu-trigger span {
background-color: transparent;
}

Now, let’s create the two other lines. The pseudo-elements will be positioned absolutely and their height is going to be the same like of their parent by setting it to 100%:

1
2
3
4
5
6
7
8
9
10
.bt-menu-trigger span:before,
.bt-menu-trigger span:after {
position: absolute;
left: 0;
width: 100%;
height: 100%;
background: #fff;
content: '';
transition: transform 0.3s;
}
Start learning web design, web development, mobile, and much more for free at Treehouse

For positioning them correctly, we’ll use translateY:

1
2
3
4
5
6
7
.bt-menu-trigger span:before {
transform: translateY(-250%);
}
.bt-menu-trigger span:after {
transform: translateY(250%);
}

The cross will be formed when opening the menu by setting the translateY to 0 and rotating the pseudo-elements accordingly:

1
2
3
4
5
6
7
.bt-menu-open .bt-menu-trigger span:before {
transform: translateY(0) rotate(45deg);
}
.bt-menu-open .bt-menu-trigger span:after {
transform: translateY(0) rotate(-45deg);
}

The unordered list with our icons will also have a fixed position and we’ll set it to the left side of the window:

1
2
3
4
5
6
7
8
9
10
.bt-menu ul {
position: fixed;
top: 75px;
left: 0;
margin: 0;
padding: 0;
width: 90px;
list-style: none;
backface-visibility: hidden;
}

Let’s set the list items and the anchors to display: block and give them full width:

1
2
3
4
5
6
.bt-menu ul li,
.bt-menu ul li a {
display: block;
width: 100%;
text-align: center;
}

Each list item will be hidden initially and the opacity will be 0. The “backward” transition of the visibility will be delayed until all the other transitions of the transform and the opacity are finished:

1
2
3
4
5
6
.bt-menu ul li {
padding: 16px 0;
opacity: 0;
visibility: hidden;
transition: transform 0.3s, opacity 0.2s, visibility 0s 0.3s;
}

Now we will transform each of the list items differently so that they are all placed in the middle and to the left until they are hidden (-100% on the Y axis):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
.bt-menu ul li:first-child {
transform: translate3d(-100%,200%,0);
}
.bt-menu ul li:nth-child(2) {
transform: translate3d(-100%,100%,0);
}
.bt-menu ul li:nth-child(3) {
transform: translate3d(-100%,0,0);
}
.bt-menu ul li:nth-child(4) {
transform: translate3d(-100%,-100%,0);
}
.bt-menu ul li:nth-child(5) {
transform: translate3d(-100%,-200%,0);
}

When opening the menu, the list items will become visible (instantly, because we are not setting a transition for it) and they will fade in. They will also move to their original positions by setting the transform3d to 0 for all axes:

1
2
3
4
5
6
.bt-menu.bt-menu-open ul li {
visibility: visible;
opacity: 1;
transition: transform 0.3s, opacity 0.3s;
transform: translate3d(0,0,0);
}

Now, let’s style the anchors. We will use an icon font and include the font reference and the icon classes in another CSS which will be provided by a service like Fontastic or the IcoMoon app.

By setting the font size of the anchor to 0 and make it transparent, we’ll hide the text:

1
2
3
4
5
6
7
.bt-menu ul li a {
display: block;
outline: none;
color: transparent;
text-decoration: none;
font-size: 0px;
}

We’ll reset the font size for the pseudo-element which contains the icon. We’ll need to use a pixel-based value because the main element has a font-size of 0 so ems won’t work here:

1
2
3
4
5
.bt-menu ul li a:before {
color: #04a466;
font-size: 48px;
transition: color 0.2s;
}

On hover we’ll make them white:

1
2
3
4
.bt-menu ul li a:hover:before,
.bt-menu ul li a:focus:before {
color: #fff;
}

And last, but not least, we want the icons to be smaller on mobile screens:

1
2
3
4
5
@media screen and (max-height: 31.125em) {
.bt-menu ul li a:before {
font-size: 32px;
}
}

And that’s all the style. Now, let’s move on to the JavaScript.

The JavaScript

Our script is pretty straightforward; when we click on the trigger anchor, we toggle the class bt-menu-open and bt-menu-close on the nav element. (Adding the closing class is only needed if you are using animation for the trigger icon effect, just like we do in demo 1. This will allow us to only play the backward animation, when we close the menu).

When we click on the overlay, we will close the menu. We’ll also add some touch support:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
(function() {
// http://stackoverflow.com/a/11381730/989439
function mobilecheck() {
var check = false;
(function(a){if(/(android|ipad|playbook|silk|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i.test(a)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(a.substr(0,4)))check = true})(navigator.userAgent||navigator.vendor||window.opera);
return check;
}
function init() {
var menu = document.getElementById( 'bt-menu' ),
trigger = menu.querySelector( 'a.bt-menu-trigger' ),
// event type (if mobile, use touch events)
eventtype = mobilecheck() ? 'touchstart' : 'click',
resetMenu = function() {
classie.remove( menu, 'bt-menu-open' );
classie.add( menu, 'bt-menu-close' );
},
closeClickFn = function( ev ) {
resetMenu();
overlay.removeEventListener( eventtype, closeClickFn );
};
var overlay = document.createElement('div');
overlay.className = 'bt-overlay';
menu.appendChild( wrapper );
trigger.addEventListener( eventtype, function( ev ) {
ev.stopPropagation();
ev.preventDefault();
if( classie.has( menu, 'bt-menu-open' ) ) {
resetMenu();
}
else {
classie.remove( menu, 'bt-menu-close' );
classie.add( menu, 'bt-menu-open' );
overlay.addEventListener( eventtype, closeClickFn );
}
});
}
init();
})();

And that’s it! I hope you enjoyed this tutorial and find it useful!
Make sure to check out the other demos. The last one is a concept for a fullscreen video player.

View demo Download source

반응형
반응형

Animo.js: CSS animation management with JavaScript

 

animo.js

A powerful little tool for managing CSS animations. Stack animations, create cross-browser blurring, set callbacks on animation completion, make magic.

Full article and demos - http://labs.bigroomstudios.com/libraries/animo-js

Animo.js: CSS animation management with JavaScript

CSS - Javascript/Added on September 30, 2013/Add to favorites

Animo.js is a powerful tool for managing CSS animations. It makes it possible to stack animations and trigger one right after another.

animo.js

반응형
반응형

기차가 6시45분에 도착하기로 돼 있다.
그것을 기다리는 건 희망이 아니다.
그것은 오기로 돼 있는 거다. 가만히 있어도 온다.
당장 이 시점에서 아무런 보장이 없는 것.
보장은 커녕, 아예 안 올 거라고 보장돼 있는 것.
그것을 기다리는 것이 희망이다.
- 홍승수 서울대 명예교수 (한국 천문학회 전 회장)

 

이루어지게 되어있는 것은 희망이 아닙니다.
쉽게 이룰 수 있는 것은 비전이 아닙니다.
이루어질 수 없다고 생각되는 것을 바라는 것이 희망이고,
쉽게 이뤄지지 않는 것이 비전입니다.
쉽게 이뤄지지 않는다고 낙담할 일이 아닙니다.
어려울수록, 불가능해 보일수록 가치가 있는 것입니다.

 

반응형

+ Recent posts