시작페이지로 즐겨찾기추가
로그인
회원가입 l 출석체크 l 마이페이지 l CGIMALL
happycgi
자료실 사이트등록 랭킹100 프로그램리뷰 관리자추천자료 초보가이드
커뮤니티
전체 펼쳐보기
퀵메뉴링크 jquery , CSS , PHP , Javascript , 무료폰트 , ASP
상세검색
 > CSS > 기타효과 > Neuro Noise (GLSL Shader) 상세정보
사이트등록
클라우드태그
Javascript
PHP
ASP
css
html
mysql
jquery
image
API
Mobile
메뉴
slide
게시판
현재접속자 84 새로고침
Neuro Noise (GLSL Shader)
소스통계정보 오류신고 및 문의
해피팀
네티즌
트위터로 보내기 페이스북으로 보내기 네이버로공유
소스분류 기타효과
다운로드 횟수 2 회
간단설명 신경 노이즈 백그라운드 효과입니다
평가하기 훌륭함 매우좋음 좋음 괜찮음 보통 별로
홈페이지바로가기 소스다운로드 데모 미리보기 스크랩하기
   

신경 흐름을 나타내는 백그라운드 효과 입니다.
마우스 커서에 의해 흐름에 외곡을 줄 수 있습니다.
HTML, CSS, JS를 사용하였습니다.
자세한 내용은 데모사이트 주소에서 확인하실 수 있습니다.



HTML
<div class="content">
    <div class="section">
        <div>
            Neural Noise
        </div>
    </div>
    <div class="section">
        <div>
            GLSL shader based on <a href="https://x.com/zozuar/" target="_blank">@zozuar</a> <a href="https://x.com/zozuar/status/1625182758745128981/" target="_blank">artwork</a>
        </div>
    </div>
    <div class="section">
        <div>
            <a href="https://linkedin.com/in/ksenia-kondrashova/" target="_blank">linkedIn</a>
  <a href="https://codepen.io/ksenia-k" target="_blank">codepen</a>
  <a href="https://x.com/uuuuuulala" target="_top">X (twitter)</a>
        </div>
    </div>
</div>
 
<canvas id="neuro"></canvas>
 
 
<script type="x-shader/x-fragment" id="vertShader">
    precision mediump float;
 
    varying vec2 vUv;
    attribute vec2 a_position;
 
    void main() {
        vUv = .5 * (a_position + 1.);
        gl_Position = vec4(a_position, 0.0, 1.0);
    }
</script>
 
<script type="x-shader/x-fragment" id="fragShader">
    precision mediump float;
 
    varying vec2 vUv;
    uniform float u_time;
    uniform float u_ratio;
    uniform vec2 u_pointer_position;
    uniform float u_scroll_progress;
 
    vec2 rotate(vec2 uv, float th) {
        return mat2(cos(th), sin(th), -sin(th), cos(th)) * uv;
    }
 
    float neuro_shape(vec2 uv, float t, float p) {
        vec2 sine_acc = vec2(0.);
        vec2 res = vec2(0.);
        float scale = 8.;
 
        for (int j = 0; j < 15; j++) {
            uv = rotate(uv, 1.);
            sine_acc = rotate(sine_acc, 1.);
            vec2 layer = uv * scale + float(j) + sine_acc - t;
            sine_acc += sin(layer);
            res += (.5 + .5 * cos(layer)) / scale;
            scale *= (1.2 - .07 * p);
        }
        return res.x + res.y;
    }
 
    void main() {
        vec2 uv = .5 * vUv;
        uv.x *= u_ratio;
 
        vec2 pointer = vUv - u_pointer_position;
        pointer.x *= u_ratio;
        float p = clamp(length(pointer), 0., 1.);
        p = .5 * pow(1. - p, 2.);
 
        float t = .001 * u_time;
        vec3 color = vec3(0.);
 
        float noise = neuro_shape(uv, t, p);
 
        noise = 1.2 * pow(noise, 3.);
        noise += pow(noise, 10.);
        noise = max(.0, noise - .5);
        noise *= (1. - length(vUv - .5));
 
        color = normalize(vec3(.2, .5 + .4 * cos(3. * u_scroll_progress), .5 + .5 * sin(3. * u_scroll_progress)));
 
        color = color * noise;
 
        gl_FragColor = vec4(color, noise);
    }
</script>
   

CSS
body, html {
    margin: 0;
    padding: 0;
    background-color: #151912;
 overflow-x: hidden;
}
 
.content {
    width: 100vw;
    font-family: 'Times New Roman', serif;
}
 
.section {
    width: 100%;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #FFF6F7;
    text-align: center;
}
 
.section > div {
    width: 90%;
}
 
.section:nth-child(1) {
    font-size: 20vh;
}
 
 
.section:nth-child(2) {
    font-size: 10vh;
}
 
.section:nth-child(3) {
    font-size: 8vh;
}
 
.section:nth-child(2) > div {
    max-width: 800px
}
 
.section:nth-child(3) > div {
    max-width: 900px
}
 
.section:nth-child(3) a {
    padding: 0 .3em;
}
 
canvas#neuro {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    pointer-events: none;
    opacity: .95;
}
 
a {
    display: inline-block;
    text-decoration: none;
    color: inherit;
    font-weight: inherit;
    font-style: inherit;
}
 
a:hover {
    font-weight: inherit;
    text-decoration: none;
    color: rgb(160, 160, 255);
}
 
a:active {
    color: rgb(160, 255, 255);
}
 
body, html {
    margin: 0;
    padding: 0;
    background-color: #151912;
}
 
.content {
    width: 100vw;
    font-family: 'Times New Roman', serif;
}
 
.section {
    width: 100%;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #FFF6F7;
    text-align: center;
}
 
.section > div {
    width: 90%;
}
 
.section:nth-child(1) {
    font-size: 20vh;
}
 
.section:nth-child(2) {
    font-size: 10vh;
}
 
.section:nth-child(3) {
    font-size: 8vh;
}
 
.section:nth-child(2) > div {
    max-width: 800px
}
 
.section:nth-child(3) > div {
    max-width: 900px
}
 
.section:nth-child(3) a {
    padding: 0 .3em;
}
 
canvas#neuro {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    pointer-events: none;
    opacity: .95;
}
 
a {
    display: inline-block;
    text-decoration: none;
    color: inherit;
    font-weight: inherit;
    font-style: inherit;
}
 
a:hover {
    font-weight: inherit;
    text-decoration: none;
    color: rgb(160, 160, 255);
}
 
a:active {
    color: rgb(160, 255, 255);
}
 

네티즌 의견   이용하신 자료의 후기를 자유롭게 작성하세요. (상업적인 광고 및 도배성 글 등은 사전통보없이 삭제될 수 있습니다.)
내용 아이디 의견남기기
등록된 의견이 없습니다.
1
이름
내용
:네맞아요: :화나는군요: :잠와: :우울해: :이건아냐: :왕하하: 왕웃음~ 놀램~
평가하기 훌륭함 매우좋음 좋음 괜찮음 보통 별로
도배방지키
 57537768 보이는 도배방지키를 입력하세요.