読者です 読者をやめる 読者になる 読者になる

Fly higher! Sky is the limit!

webの現場で働く人のブログ

[JQuery]たった9行でInstagram(インスタグラム)の写真一覧をWebサイトに表示する。

jQuery JS

準備するもの

参考サイト

InstagramのAPIを使用して自分の投稿した写真をWEBサイトに出力する

instagram api 事始め access_tokenを取得する - Qiita

Instagram APIを取得してWebサイトと連携し、投稿写真を自動に掲載する方法 | 株式会社LIG

この辺の記事を参考にするとよい。

アクセストークンについて

もし「アプリの登録はできたけど、Instagramのアクセストークンが取得できない!」という場合、以下のページにアクセスし「Generate Access Token」をクリックすると良いかもしれないです。

instagram.pixelunion.net

※ ちなみに私はこちらのサイトを利用しました。

準備ができたところで、本題。

HTML

<ul id="js-instalib"></ul>

JavaScript

$(function(){
  var accessToken = 'xxxxxxxx.xxxxxxx.xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'; //取得したアクセストークンを貼り付ける
  $.getJSON('https://api.instagram.com/v1/users/self/media/recent/?access_token='+accessToken+'&callback=?',function (insta) {
    $.each(insta.data,function (photos,src) {
      if ( photos === 10 ) { return false; } //上限設定
      $('<li><img src="'+src.images.standard_resolution.url+'"></li>').appendTo('#js-instalib');
    });
  });
});

css

お好みで調整

DEMO

See the Pen insta lib by @paradox_tm (@takumaro-web) on CodePen.

編集後記

//api.instagram.com/v1/users/self/media/recent/?access_token=[アクセストークン]にアクセスすると いいね数やコメント、時間、リンク先など様々な情報が載っているので必要に応じてカスタマイズするのもありですね。

参考オプション

//インスタグラム詳細URL
src.link
//いいね数
src.likes.count
//コメント数
src.comments.count
//自分のコメント
src.caption.text

TweenMaxを使ってオープニングアニメーションをつくる。

JS

TweenMaxを使ってオープニングアニメーションをつくる。

日本でもTweenMax(トゥイーンライブラリ)を使用しているリッチサイトが大分増えてきた気がますねー。 大体、動きがかっくいいサイトのソースを覗くと「TweenMax」の文字が見受けられます!

本記事は、TimelineMaxの基本的なアニメーション操作と記述方法のメモ書き。

オープニングアニメーションっぽい適当なDEMO| TimelineMax

See the Pen TweenMax sample by @paradox_tm (@takumaro-web) on CodePen.

以下、ソース抜粋

//TweenMaxを使用するための宣言
var timeLine = new TimelineMax();

//セレクターを指定
var elm1 =  document.getElementById("js-anim-01");
var elm2 =  document.getElementById("js-anim-02");
var elm3 =  document.getElementById("js-anim-03");
var elm4 =  document.getElementById("js-anim-04");
var elm5 =  document.getElementById("js-anim-05");
var elm6 =  document.getElementById("js-anim-06");

//第1引数:セレクター指定.
//第2引数:秒数指定(1000msではなく1秒単位).
//第3引数:アニメーション指定.
//第4引数:オプション指定.

//.toでタイムラインをつくっていく。
//コールバックは、onComplete: function(){}を指定.

//詳しくは以下を参照
//https://greensock.com/get-started-js
//https://ihatetomatoes.net/wp-content/uploads/2016/07/GreenSock-Cheatsheet-4.pdf

timeLine.to(elm1, 1, {opacity: '1', x:0, rotation:360}, "blueGreenSpin")
        .to(elm1, 1, {opacity: '0'})
        .to(elm2, 1, {top: '50%',opacity: '1'})
        .to(elm2, 1, {opacity: '0'})
        .to(elm3, 1, {right: '40%',opacity: '1'})
        .to(elm3, 1, {opacity: '0'})
        .to(elm4, 1, {opacity: '1', width:"50%", top:"100px", ease:Power2.easeInOut})
        .to(elm4, 1, {opacity: '0'})
        .to(elm5, 1, {opacity: '1', x:0, y:0, rotation:1440})
        .to(elm5, 2, {opacity: '0',top:'60%', ease:Power2.easeOut, onComplete:
                      function(){
                        //アニメーションが終わった後の処理
                     }})
        .to(elm6, 1, {opacity: '1',scale:"2"});

CDNの利用

2016年7月16日に最新版の1.19.0をリリースされた模様。 greensock.com

Cheat Sheet

https://ihatetomatoes.net/wp-content/uploads/2016/07/GreenSock-Cheatsheet-4.pdf

触ってみての感想

直感的でわかりやすい!!
他にも色々なオプションがたくさんある!!
Canvas/WebGLなどの制御も可能!!
jQueryも使える!!

胸がワキワキしちゃいますね!

facebookのOGPキャッシュをボタン1つで消せるBookmarkletを作製しました。

ページ公開直後のコンテンツに対してシェアボタンを押してもOGP情報をうまく取得できずシェアされない場合がありますよねー。 これは公開前のURLにfacebookのクローラがアクセスしてしまうことによって、facebook側にキャッシュが残ってしまいそちらを参照してしまうのが原因だそう。 (つまり、空ページをfacebook側がキャッシュしてしまっている。)

今まではページが公開されるとfacebook側が提供しているデバッグページにてキャッシュをクリアしていたけど少し煩わしさを感じていた。 いちいちfacebookにログインしなきゃいけないし、対象のURLをコピーして貼り付けなきゃだし、ボタンを押さなきゃいけないわけで...

『なんとかこの作業について簡略化・自動化できないか』と調べたところAPIの「https://graph.facebook.com/?scrape=true&id=URL」にPOSTメソッドでアクセスすると、再クロールしてくれるという記事を発見!

公開ページそのものにこのスクリプトないしプログラムを組み込めば、完全に自動化できるけど閲覧する度にPOSTするのもパフォーマンス的にいかがなものか? と思いBookmarkletでポチッとボタンを押すだけでキャッシュを消すことができるものを作製することにした。

自分は普段使いのブラウザがChromeなのでこちらのBookmarkletで問題ないのだが、現場から「Firefoxで動かねぇーよ!」という声が上がってきた。実際に確認してみるとなぜか、FirefoxだとBookmarklet内でAjaxを使ってPOSTできない..(誰かエロい人教えてください。)

2016/9/8修正
実は圧縮でミスってることがわかりました。
YUI Compressorを使用していたのですが、圧縮に問題が...
他の圧縮ツールを使用したところ、問題なくできたのでこちらを使用ください。
こちらは、Firefox/Chromeでも使用できます。

Bookmarkletソース(Firefox/Chrome用)

javascript:(function(){!function(c,b,a){a=c.createElement("script");a.src="//j.mp/1bPoAXq";a.onload=function(){b(jQuery.noConflict(1))};c.body.appendChild(a)}(document,function(a){a.ajax({url:"https://graph.facebook.com/?scrape=true&id="+location.href,method:"post"}).done(function(){alert("OGPキャッシュを消しましたー。")})})})();

これで、facebook側が提供しているデバッグページを使わずに済むので煩わしさが無くなりそう。

ちなみにIEsafariでは試してないです。

参考

web-tan.forum.impressrd.jp

developers.facebook.com

superuser.com

【canvas】画像を回転させながら落とす

最近、インタラクティブな実装に興味を持ち始めました。
覚え書きとして、canvasで画像を用いて回転させながら落ちるアニメーションの実装方法を記しておきます。

DEMO

補足
- 画像を複数個使用することを想定して、配列を用いています。

JavaScriptコード

$(function(){
var canvas = document.getElementById ('canvas');
var ctx = canvas.getContext ('2d');

function canvasbg(pageY,pageX,flag){
  var counter1 = 0;
  var counter2 = 0;
  var TO_RADIANS = Math.PI/180;
  var SPEED = 5;
  var X = pageX;
  var Y = pageY;

  function start() {

    x = [];
    y = [];

    /*初期座標*/
    x[0] = X / 2;
    y[0] = 0;
    
    x[1] = 150;
    y[1] = 0;

    img = [];
    img[0] = new Image ();
    img[0].src = "";
    
     img[1] = new Image ();
     img[1].src = "";
    // img[2] = new Image ();
    // img[2].src = "";
    // img[3] = new Image ();
    // img[3].src = "";
    // img[4] = new Image ();
    // img[4].src = "";
    // img[5] = new Image ();
    // img[5].src = "";

    var time;
    time = setInterval(function(){
      draw(X,Y);
    },SPEED);

  }

  function draw(X,Y) {
    ctx.clearRect (0 , 0 , pageX , pageY);
    drawRotatedImage(img[0],x[0], y[0],counter1);
    drawRotatedImage(img[1],x[1], y[1],counter2);

    /*回転用 角度*/
    counter1 += 0.5;
    counter2 += 0.3; 

    /*落下スピード*/
    x[0] -= 1 * Math.random();
    y[0] += 2;
  
    x[1] -= 1 * Math.random();
    y[1] += 1;

    /*再描画判定座標*/
    if(y[0] > pageY + 20){
      x[0] = pageX / 2;
      y[0] = 0;
    }
    if(y[1] > pageY + 20){
      x[1] = pageX / 3;
      y[1] = 0;
    }
  }

  /*回転*/
  function drawRotatedImage(image, x, y, angle) {
    ctx.save(); 
    ctx.translate(x, y);
    ctx.rotate(angle * TO_RADIANS);
    ctx.drawImage(image, -(image.width/2), -(image.height/2));
    ctx.restore();
  }

  /*ループ*/
  window.requestAnimationFrame = (function(){
    return  window.requestAnimationFrame   ||
        window.webkitRequestAnimationFrame ||
        window.mozRequestAnimationFrame    ||
        window.oRequestAnimationFrame      ||
        window.msRequestAnimationFrame     ||
        function(callback){
          window.setTimeout(callback, 1000 / 60);
        };
  })();

  requestAnimationFrame(start);
  sizing();
}

  function sizing(){
    $('#canvas').attr({height:$('#wrap').height()});
    $('#canvas').attr({width:$('#wrap').width()});
  }

  $(window).load(function(){
    pageY = $('#wrap').height();
    pageX = $('#wrap').width();
    canvasbg(pageY,pageX,0);
  });
  
});
  • 初期座標、イメージパスを指定する。
  • 画像を描画する際に回転用の関数を使用する。
  • 角度をつける(インクリメント)
  • 落下スピードを指定する。
  • 最下部までいったら元の位置に戻す。

応用として、「雪」「落ち葉」「雨」などにも適応できそうです。

配列の宣言で警告。

JSHintで警告が出ていた。

the array literal notation [] is preferable

日本語訳 :“配列リテラルの表記が好ましいっすね。”

配列の初期化宣言にリテラルを使った方がよいらしい。

x = new Array ();

x = [];

以上、覚書でした。

リテラルとは、プログラムのソースコードにおいて使用される、数値や文字列を直接に記述した定数のことである。 変数の対義語であり、変更されないことを前提とした値である。 プログラミング言語のコード中にリテラルが挿入される場合には、判別のために特定の書式を用いる必要がある。

www.weblio.jp

最近よく使う、CSSプロパティ 3選(vw/vh,calc(),flex) - #レスポンシブwebデザイン

ここ最近よく使うなーと思うCSSプロパティの紹介。

Viewport units: vw, vh, vmin, vmax

ビューポートの縦・横に対する割合の単位ですが、
めっちゃ使えるなぁーと思う今日この頃です。

記事紹介

coliss.com

dev.classmethod.jp

Can I use 状況

Can I use... Support tables for HTML5, CSS3, etc

Android4.3以下は、フォールバックを用意しておけばガンガン使えんじゃん! って感じでガンガン使ってます。

特にお気に入りは、ビューポートに合わせて文字サイズが変更できるところですね。

coliss.com

※ 一部次に紹介するcalc()との組み合わせの内容が含まれております。

対象ブラウザや要件定義が合えば積極的に使っていきたいですね!

calc() as CSS unit value

calc()関数です。 calc = calculation(計算)の略でその名の通り、四則計算ができます。

レスポンシブwebデザインをやる上で今までは、Sass(SCSS)内で計算させて横幅等を指定していたのですが、 これを使えば、そのまま「計算式」を「値」として指定できます。

もちろん、さらに洗練されたmixinにしても使えますね。

記事紹介

www.sassmeister.com

hyper-text.org

Can I use 状況

Can I use... Support tables for HTML5, CSS3, etc

Android4.3以下は、フォールバックを用意しておけばガンガン使えんじゃん! って感じでガンガン使ってます。

疑似要素で上下に画像を配置し、間の高さだけ背景を指定したい!といった場合に calc(高さ - 疑似要素で配置した大きさ*2 ) のように指定できたのに感動した記憶があります。

Flexible Box Layout Module

言わずもがなな感じがしていますが、便利ですねー。

記事紹介

coliss.com

css3のflexboxを使うとすごい簡単になるレイアウトを試してみた | スターフィールド株式会社

www.webcreatorbox.com

Can I use 状況

Can I use... Support tables for HTML5, CSS3, etc

ほぼ、接頭辞を付ければ問題なく使えます。 今まで、JSで高さ揃えを実装し構築してたものについても、CSSのプロパティ1つで済む可能性があるというのはかなりでかい点ですね。

以上、最近よく使う、CSSプロパティ 3選でした。

【自分メモ】cookieの値を取得する。

特定のcookieの値をだけを取得したい場合。

var getCookieValue = function(key) {
    var val = document.cookie.match(new RegExp('(^|\\s)'+key+'=([^;]+)'));
    return !!val && unescape(val[2]);
};

alert(getCookieValue("COOKIE名"));

参考URL blog.manaten.net

cookies.jsを使用した場合。

参考URL developer.mozilla.org

 /*\
 |*|
 |*|  :: cookies.js ::
 |*|
 |*|  A complete cookies reader/writer framework with full unicode support.
 |*|
 |*|  https://developer.mozilla.org/en-US/docs/DOM/document.cookie
 |*|
 |*|  Syntaxes:
 |*|
 |*|  * docCookies.setItem(name, value[, end[, path[, domain[, secure]]]])
 |*|  * docCookies.getItem(name)
 |*|  * docCookies.removeItem(name[, path])
 |*|  * docCookies.hasItem(name)
 |*|  * docCookies.keys()
 |*|
 \*/

var docCookies = {
  getItem: function (sKey) {
    if (!sKey || !this.hasItem(sKey)) { return null; }
    return unescape(document.cookie.replace(new RegExp("(?:^|.*;\\s*)" + escape(sKey).replace(/[\-\.\+\*]/g, "\\$&") + "\\s*\\=\\s*((?:[^;](?!;))*[^;]?).*"), "$1"));
  },
  setItem: function (sKey, sValue, vEnd, sPath, sDomain, bSecure) {
    if (!sKey || /^(?:expires|max\-age|path|domain|secure)$/i.test(sKey)) { return; }
    var sExpires = "";
    if (vEnd) {
      switch (vEnd.constructor) {
        case Number:
          sExpires = vEnd === Infinity ? "; expires=Tue, 19 Jan 2038 03:14:07 GMT" : "; max-age=" + vEnd;
          break;
        case String:
          sExpires = "; expires=" + vEnd;
          break;
        case Date:
          sExpires = "; expires=" + vEnd.toGMTString();
          break;
      }
    }
    document.cookie = escape(sKey) + "=" + escape(sValue) + sExpires + (sDomain ? "; domain=" + sDomain : "") + (sPath ? "; path=" + sPath : "") + (bSecure ? "; secure" : "");
  },
  removeItem: function (sKey, sPath) {
    if (!sKey || !this.hasItem(sKey)) { return; }
    document.cookie = escape(sKey) + "=; expires=Thu, 01 Jan 1970 00:00:00 GMT" + (sPath ? "; path=" + sPath : "");
  },
  hasItem: function (sKey) {
    return (new RegExp("(?:^|;\\s*)" + escape(sKey).replace(/[\-\.\+\*]/g, "\\$&") + "\\s*\\=")).test(document.cookie);
  },
  keys: /* optional method: you can safely remove it! */ function () {
    var aKeys = document.cookie.replace(/((?:^|\s*;)[^\=]+)(?=;|$)|^\s*|\s*(?:\=[^;]*)?(?:\1|$)/g, "").split(/\s*(?:\=[^;]*)?;\s*/);
    for (var nIdx = 0; nIdx < aKeys.length; nIdx++) { aKeys[nIdx] = unescape(aKeys[nIdx]); }
    return aKeys;
  }
}


alert(docCookies.getItem("COOKIE名"));