無料でキャラクター作成、動くアバター

皆さん、こんにちは。

無料でキャラクター作成、今回は、振り返るアバターを作ってみます。

GIF画像がどうしても画像をつなぎ合わせるのと、ループしているので、忙しい感じがしていました。それを、もう少し上手くつないで振り返るアイコンの様に出来ないかと思っています。

少し、試作で作ってみたのですが、瞬きの様には上手く行きませんでした。瞬きは、動く範囲が少ないので画像をつないでも違和感があまりなかったのですが、振り返りとなると90°近くは動いて来るのでどうしてもカクカク感が目立ちました。

このサイトにもスライドショー用に、Smart Slider 3 と言うプラグインを入れて使っていますが、画像と画像のつなぎにトランジション(つなぎの動き)を入れる事が出来ます。

これを使う事で、画像のつなぎがふわっとして、緩やかに入れ替わります。

残念ながら、photoPea も Giam もこれは出来ないのです。少し調べてみると Photoshop では、出来る様ですが、この為に月額 1078円支払うのは、現実的では有りませんし、他に良い方法は、と思っていると、動画編集ソフトでも出来る様です。

色々なサイトで、10選とかやっているので見てみまして、最終2つに絞りました。

VideoProc Converter 無料版と Com Lab です。評価等で見てみますと、どちらも無料版なので、かなりしっかり目に、製品版を購入しませんかの広告が入る様です。

VideoProc Converter 無料版は、出力度に買いませんか?と聞いて来るので、一寸…。

大体、同等の性能で、動画編集がメインでは無く変換する事を主な目的としている感じでした。今回の製品選択は、無料でGIF画像を作る為の方法を探しているので、それで十分だと考えました。

次に、もしソフトが気に入って購入する場合

例えば、本格的に画像編集がやって見たくなった場合は、もっと機能の充実した他のソフトも視野に入って来るでしょうし、広告画面が嫌で購入するなら、GMO Mix Pro が有る(2,990円、此方が有料で最安)此方かなと考えました。

では、ダウンロードから始めてみます。ダウンロードサイトは、此方です。

【公式】 誰でも使いやすい動画編集ソフトGOM Mix 2024 | GOMミックス
GOM Mix 2024は初心者でも、誰でも容易く使える最も簡単な動画編集ソフトです。素敵なフィルター、ステッカー、PIP、クロマキーなど、高級機能まで!今すぐ無料で利用してみてください。

やろうとしている事と、本来のソフト使用方法が離れているせいで💦、出ている情報だけではわからない事も有り、結局、両方ダウンロードしてみる事になりました(涙)。

Com LabVideoProc Converter
出来る事JPG画像、PNG画像の取り込み
画像つなぎのトランジション
MP4出力
静止画は取り込めない
GIF形式の出力と全体時間調整
出来ない事GIF形式の出力
出力時の背景色指定(黒しか出来ない)
静止画の編集

この段階で、1個のソフトでは出来ないと言う事が分かり、Com Labでサンプルも作ってみたのですが、トランジションの効果が自分の思っていた感じと違ったりして、少し行き詰っていました。

それと、画像の最短表示時間が1秒と決まっているので、(瞬き動画の場合ですと1枚の画像時間が50/1秒位)これも調整が必要になります。

一寸、うーんとなっていたのですが、VideoProc Vloggerとソフトに行き着きました。VideoProc Converterと同じ会社が作っています。どうしてもっと早く気が付かなかったのかと言うと、完全無料をとなっていて、有料のソフトが目立っていたせいかも…。

サンプルを作ってみたのですが、トランジションの効果(クロスフェード)が綺麗で、画像のつなぎが美しい、それと出力の際に背景色指定が出来ます。

Com Labは黒しか出来ない(PNG画像の様に無背景の時)様です。VideoProc Vloggerもデフォルトは黒でしたが、好きな色に変更出来ました。

背景が黒ですと、ブログなどに使う場合少し違和感が出ます。記事背景も白の方が多いと思いますし、カスタマイズも出来る様ですので、お好きな色に変更可能な様です。

最初から、JPG画像にして背景を白にすれば良いのですが、キャラクターをGIF形式だけで使わず、ほかの用途でも(例えば、別の背景を合わせる場合)使いたい場合は、PNG画像が便利です。

それと、トランジション効果も時間の保存が出来て、ワンクリックで全ての画像に付ける事が出来るのも便利だと感じました。この、トランジションを使ったGIF画像は、カクカク見えにくい事の他に、最初に作る画像の少なさがメリットです。

90°ほど振り返るGIF動画をやって見ようと、10枚の画像にしましたが、未だ大分カクカクしていました。それを4枚にしてクロスフェードで繋げると、結構、思った感じになった(自画自賛、すみません)気がしたのです。

VideoProc Vlogger 公式

【公式】VideoProc Vlogger - 無料で使える動画編集ソフト|動画編集ならこれにお任せ!
『VideoProc Vlogger』は人気急上昇中のフリー動画編集ソフト。動画作成&動画加工・4K編集もおまかせ!!初心者が簡単に始められるおすすめの無料の動画編集ソフト。VideoProc Vloggerで、笑顔の1日を始めよう!

ダウンロードページを見ても、良くある購入ページへの誘導も無い様ですし、機能に満足すれば、良いアイテムだと思います。

しかし、もしかしたら、動画編集ソフトはこれがデフォルトなのかもしれないですが、1枚画像の最小表示時間が1秒の為、いくつかの工程を進めて、仕上げて来ます。

ご自身の作ったキャラクターで簡単動画良いな!とお考えでしたら、一度、見てみて下さい。

次回は、作業を進めて見ます。

おつかれさまでした。

コメント

");const o=ie?ie.createHTML(e):e;if(nt===tt)try{t=(new W).parseFromString(o,at)}catch(e){}if(!t||!t.documentElement){t=le.createDocument(nt,"template",null);try{t.documentElement.innerHTML=ot?ae:o}catch(e){}}const i=t.body||t.documentElement;return e&&n&&i.insertBefore(r.createTextNode(n),i.childNodes[0]||null),nt===tt?ue.call(t,Ie?"html":"body")[0]:Ie?t.documentElement:i},bt=function(e){return ce.call(e.ownerDocument||e,e,H.SHOW_ELEMENT|H.SHOW_COMMENT|H.SHOW_TEXT|H.SHOW_PROCESSING_INSTRUCTION|H.SHOW_CDATA_SECTION,null)},St=function(e){return e instanceof B&&("string"!=typeof e.nodeName||"string"!=typeof e.textContent||"function"!=typeof e.removeChild||!(e.attributes instanceof z)||"function"!=typeof e.removeAttribute||"function"!=typeof e.setAttribute||"string"!=typeof e.namespaceURI||"function"!=typeof e.insertBefore||"function"!=typeof e.hasChildNodes)},Rt=function(e){return"function"==typeof b&&e instanceof b},wt=function(e,t,n){pe[e]&&u(pe[e],(e=>{e.call(o,t,n,ut)}))},Ct=function(e){let t=null;if(wt("beforeSanitizeElements",e,null),St(e))return _t(e),!0;const n=st(e.nodeName);if(wt("uponSanitizeElement",e,{tagName:n,allowedTags:Ne}),e.hasChildNodes()&&!Rt(e.firstElementChild)&&_(https://b-ume.net/<[/\w]/g,e.innerHTML)&&_(https://b-ume.net/<[/\w]/g,e.textContent))return _t(e),!0;if(e.nodeType===J)return _t(e),!0;if(Me&&e.nodeType===Q&&_(https://b-ume.net/<[/\w]/g,e.data))return _t(e),!0;if(!Ne[n]||Ce[n]){if(!Ce[n]&&Dt(n)){if(we.tagNameCheck instanceof RegExp&&_(we.tagNameCheck,n))return!1;if(we.tagNameCheck instanceof Function&&we.tagNameCheck(n))return!1}if(Ye&&!qe[n]){const t=re(e)||e.parentNode,n=oe(e)||e.childNodes;if(n&&t){for(let o=n.length-1;o>=0;--o){const r=X(n[o],!0);r.__removalCount=(e.__removalCount||0)+1,t.insertBefore(r,$(e))}}}return _t(e),!0}return e instanceof R&&!Et(e)?(_t(e),!0):"noscript"!==n&&"noembed"!==n&&"noframes"!==n||!_(/<\/no(script|embed|frames)/i,e.innerHTML)?(ke&&e.nodeType===Z&&(t=e.textContent,u([fe,de,he],(e=>{t=g(t,e," ")})),e.textContent!==t&&(p(o.removed,{element:e.cloneNode()}),e.textContent=t)),wt("afterSanitizeElements",e,null),!1):(_t(e),!0)},Lt=function(e,t,n){if(Be&&("id"===t||"name"===t)&&(n in r||n in mt))return!1;if(ve&&!Le[t]&&_(ge,t));else if(De&&_(Te,t));else if(!Se[t]||Le[t]){if(!(Dt(e)&&(we.tagNameCheck instanceof RegExp&&_(we.tagNameCheck,e)||we.tagNameCheck instanceof Function&&we.tagNameCheck(e))&&(we.attributeNameCheck instanceof RegExp&&_(we.attributeNameCheck,t)||we.attributeNameCheck instanceof Function&&we.attributeNameCheck(t))||"is"===t&&we.allowCustomizedBuiltInElements&&(we.tagNameCheck instanceof RegExp&&_(we.tagNameCheck,n)||we.tagNameCheck instanceof Function&&we.tagNameCheck(n))))return!1}else if(Ze[t]);else if(_(Ae,g(n,Ee,"")));else if("src"!==t&&"xlink:href"!==t&&"href"!==t||"script"===e||0!==T(n,"data:")||!Ke[e]){if(Oe&&!_(ye,g(n,Ee,"")));else if(n)return!1}return!0},Dt=function(e){return"annotation-xml"!==e&&h(e,_e)},vt=function(e){wt("beforeSanitizeAttributes",e,null);const{attributes:t}=e;if(!t)return;const n={attrName:"",attrValue:"",keepAttr:!0,allowedAttributes:Se};let r=t.length;for(;r--;){const i=t[r],{name:a,namespaceURI:l,value:c}=i,s=st(a);let p="value"===a?c:y(c);if(n.attrName=s,n.attrValue=p,n.keepAttr=!0,n.forceKeepAttr=void 0,wt("uponSanitizeAttribute",e,n),p=n.attrValue,n.forceKeepAttr)continue;if(At(a,e),!n.keepAttr)continue;if(!xe&&_(/\/>/i,p)){At(a,e);continue}if(Me&&_(/((--!?|])>)|<\/(style|title)/i,p)){At(a,e);continue}ke&&u([fe,de,he],(e=>{p=g(p,e," ")}));const f=st(e.nodeName);if(Lt(f,s,p)){if(!We||"id"!==s&&"name"!==s||(At(a,e),p=Ge+p),ie&&"object"==typeof G&&"function"==typeof G.getAttributeType)if(l);else switch(G.getAttributeType(f,s)){case"TrustedHTML":p=ie.createHTML(p);break;case"TrustedScriptURL":p=ie.createScriptURL(p)}try{l?e.setAttributeNS(l,a,p):e.setAttribute(a,p),St(e)?_t(e):m(o.removed)}catch(e){}}}wt("afterSanitizeAttributes",e,null)},Ot=function e(t){let n=null;const o=bt(t);for(wt("beforeSanitizeShadowDOM",t,null);n=o.nextNode();)wt("uponSanitizeShadowNode",n,null),Ct(n)||(n.content instanceof s&&e(n.content),vt(n));wt("afterSanitizeShadowDOM",t,null)};return o.sanitize=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=null,r=null,i=null,l=null;if(ot=!e,ot&&(e="\x3c!--\x3e"),"string"!=typeof e&&!Rt(e)){if("function"!=typeof e.toString)throw A("toString is not a function");if("string"!=typeof(e=e.toString()))throw A("dirty is not a string, aborting")}if(!o.isSupported)return e;if(Ue||ft(t),o.removed=[],"string"==typeof e&&(je=!1),je){if(e.nodeName){const t=st(e.nodeName);if(!Ne[t]||Ce[t])throw A("root node is forbidden and cannot be sanitized in-place")}}else if(e instanceof b)n=Nt("\x3c!----\x3e"),r=n.ownerDocument.importNode(e,!0),r.nodeType===V&&"BODY"===r.nodeName||"HTML"===r.nodeName?n=r:n.appendChild(r);else{if(!Fe&&!ke&&!Ie&&-1===e.indexOf("<"))return ie&&ze?ie.createHTML(e):e;if(n=Nt(e),!n)return Fe?null:ze?ae:""}n&&Pe&&_t(n.firstChild);const c=bt(je?e:n);for(;i=c.nextNode();)Ct(i)||(i.content instanceof s&&Ot(i.content),vt(i));if(je)return e;if(Fe){if(He)for(l=se.call(n.ownerDocument);n.firstChild;)l.appendChild(n.firstChild);else l=n;return(Se.shadowroot||Se.shadowrootmode)&&(l=me.call(a,l,!0)),l}let m=Ie?n.outerHTML:n.innerHTML;return Ie&&Ne["!doctype"]&&n.ownerDocument&&n.ownerDocument.doctype&&n.ownerDocument.doctype.name&&_(q,n.ownerDocument.doctype.name)&&(m="\n"+m),ke&&u([fe,de,he],(e=>{m=g(m,e," ")})),ie&&ze?ie.createHTML(m):m},o.setConfig=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};ft(e),Ue=!0},o.clearConfig=function(){ut=null,Ue=!1},o.isValidAttribute=function(e,t,n){ut||ft({});const o=st(e),r=st(t);return Lt(o,r,n)},o.addHook=function(e,t){"function"==typeof t&&(pe[e]=pe[e]||[],p(pe[e],t))},o.removeHook=function(e){if(pe[e])return m(pe[e])},o.removeHooks=function(e){pe[e]&&(pe[e]=[])},o.removeAllHooks=function(){pe={}},o}();return oe}))
タイトルとURLをコピーしました