1. ホーム
  2. DIY、工具
  3. 住宅設備
  4. 屋外照明
  5. ソーラーライト ガラスボトル型(2個セット)LEDライト ガラス ガーデンライト 屋外照明 防水 おしゃれ 庭 ソーラー充電式 夜間自動点灯 電気不要
2021年レディースファッション福袋 2022新作 ソーラーライト ガラスボトル型 2個セット LEDライト ガラス ガーデンライト 屋外照明 防水 おしゃれ 庭 ソーラー充電式 夜間自動点灯 電気不要 pfsa131.com pfsa131.com

ソーラーライト ガラスボトル型(2個セット)LEDライト ガラス ガーデンライト 屋外照明 防水 おしゃれ 庭 ソーラー充電式 夜間自動点灯 電気不要

822円

ソーラーライト ガラスボトル型(2個セット)LEDライト ガラス ガーデンライト 屋外照明 防水 おしゃれ 庭 ソーラー充電式 夜間自動点灯 電気不要

明るい色:暖かい光、彩色の光
数量:2個
サイズ:12 * 14 * 16CM
充電時間:約6〜8時間のソーラー充電(直射日光下)
点灯時間:約8時間
バッテリー:600mah
光源:20LED銅線ストリングライト
材質:ガラス、ABS

注意:
1.使用する前に、スイッチがオンになっていることを確認してください。
2.ガラス室、監視エリア、その他の照明時間が短いエリアへの設置には適していません(直射日光の当たる場所に6時間以上設置する必要があります)。
※充電時間と照明時間は目安となりますので、天候によって異なります。
※ PC環境により実際の色味や質感と異なる場合がございます。



















ソーラーライト ガラスボトル型(2個セット)LEDライト ガラス ガーデンライト 屋外照明 防水 おしゃれ 庭 ソーラー充電式 夜間自動点灯 電気不要

椎茸昆布佃煮 60g
ソーラーライト ガラスボトル型(2個セット)LEDライト ガラス ガーデンライト 屋外照明 防水 おしゃれ 庭 ソーラー充電式 夜間自動点灯 電気不要 :lj3-21062900111:YoshiYoshi - 通販 - Yahoo!ショッピングソーラーライト ガラスボトル型(2個セット)LEDライト ガラス ガーデンライト 屋外照明 防水 おしゃれ 庭 ソーラー充電式 夜間自動点灯 電気不要  :lj3-21062900111:YoshiYoshi - 通販 - Yahoo!ショッピング
楽天市場】ガーデンライト 6個セット ソーラーライト ガラス ボトル型 屋外 吊り下げ ランタン ソーラー充電 明るい アンティーク 自動点灯 LED 防水 照明 防犯 光センサー 電球色 カラフル テラス ガーデニング 庭装飾 電源不要 太陽光発電 : スーパーゼール楽天市場】ガーデンライト 6個セット ソーラーライト ガラス ボトル型 屋外 吊り下げ ランタン ソーラー充電 明るい アンティーク 自動点灯 LED  防水 照明 防犯 光センサー 電球色 カラフル テラス ガーデニング 庭装飾 電源不要 太陽光発電 : スーパーゼール
3
森林を頼んだのに無香料が届きました

トヨタ純正 プリウス フロントコイルスプリングシートRH LH 48471-42010
ソーラーライト ガラスボトル型(2個セット)LEDライト ガラス ガーデンライト 屋外照明 防水 おしゃれ 庭 ソーラー充電式 夜間自動点灯 電気不要 :tinsei0725-tdeng78:TINSEIヤフー店 - 通販 - Yahoo!ショッピングソーラーライト ガラスボトル型(2個セット)LEDライト ガラス ガーデンライト 屋外照明 防水 おしゃれ 庭 ソーラー充電式 夜間自動点灯 電気不要  :tinsei0725-tdeng78:TINSEIヤフー店 - 通販 - Yahoo!ショッピング
ソーラーライト ガラスボトル型(2個セット)LEDライト ガラス ガーデンライト 屋外照明 防水 おしゃれ 庭 ソーラー充電式 夜間自動点灯 電気不要 :lj3-21062900111:YoshiYoshi - 通販 - Yahoo!ショッピングソーラーライト ガラスボトル型(2個セット)LEDライト ガラス ガーデンライト 屋外照明 防水 おしゃれ 庭 ソーラー充電式 夜間自動点灯 電気不要  :lj3-21062900111:YoshiYoshi - 通販 - Yahoo!ショッピング
楽天市場】ガーデンライト ソーラー 屋外 防水 おしゃれ 可愛い ランタン ソーラーライト LED 庭 ガーデニング 玄関 充電式 ブラック ホワイト 黒 白 太陽光 LEDライト 防犯 防雨 置き型 レトロ 省エネ 足下灯 キャンプ アウトドア シャッテ Schatte KL10374-10375 ...楽天市場】ガーデンライト ソーラー 屋外 防水 おしゃれ 可愛い ランタン ソーラーライト LED 庭 ガーデニング 玄関 充電式 ブラック ホワイト  黒 白 太陽光 LEDライト 防犯 防雨 置き型 レトロ 省エネ 足下灯 キャンプ アウトドア シャッテ Schatte KL10374-10375  ...
ニッカ アップルブランデー XO 白 660ml 40度 ブランデー りんご nikka brandy 長S
tkhr 5
ライトブラウンのベンチを5,172円で購入しました。ダンボールの中には緩衝材がたくさんで、丁寧な梱包状態でした。シート部分と足は外れた状態。足にはネジ穴が埋め込まれており、1足2本のネジでシートと固定します。とても5,000円程度の家具とは思えないほど、しっかりとした作りになっています。シートの一部には、木材塗料が付着したと思われる赤いシミがチラホラ付いていたり、ネジ穴を開けた際の木屑が剥がし切れていなかったりと、ベトナム工場の製品管理のずさんさを感じはしますが、どうせ使っていくうちに汚れるものですし、設計がしっかりしてるので、グラつき・ガタつきはなく、構造には安心感があります。座り心地は、合皮の中に低反発ウレタンという感じで、座ると蒸れます。カバーを掛ければなんとでもなるので、こちらの減点対象にはならないですね。これなら8,000円でも十分に勝負できる品物だと思います。10,000円にするなら、もう少し完成検査をしっかりしてもらいたいですね。

パナソニック 配線器具アドバンスシリーズ テレビターミナル テレビコンセント(高シールドF型接栓) 分配配線方式 4K・8K対応(3.2GHz) グレー
西村ひろゆき 3
セール品で買ったから仕方ないのか?板はキズ結構入ってるし、キズを黒で塗って隠して出品してる。返品を破棄せずセール品で出品してるんやろけど。板をポールにはめる部品も位置が2ミリずつズレてはまらなかったし、二段目の幅が49cmになってたから買ったのに実際46cmしかなくオーブンレンジが二段目に入らない。サイズの表示がおかしくポールの外から外までが49cmでポール含まれてたから騙された最悪です部品の位置ズレは穴あけ直せばいいし、キズは多めにみようと、ちょうど段ボールの回収日だったので箱を捨てたけどオーブンレンジが入らんのは買った意味がない。箱捨てたから返品も出来んから腹立つ⚡ここでは二度と買わない‼️

消臭・調湿 木炭シート 国産赤松 88cm×400cm 4枚入り 6帖用 日本製
ソーラーライト ガラスボトル型 2個セット LEDライト ガラス ガーデンライト 屋外 防水 照明 おしゃれ 電球色 ソーラー充電式 夜間自動点灯 電気不要 国華園 :sa1766:花と緑 国華園 - 通販 - Yahoo!ショッピングソーラーライト ガラスボトル型 2個セット LEDライト ガラス ガーデンライト 屋外 防水 照明 おしゃれ 電球色 ソーラー充電式 夜間自動点灯  電気不要 国華園 :sa1766:花と緑 国華園 - 通販 - Yahoo!ショッピング
カーテン & レース セット ディズニー リーフ柄1級遮光 遮熱 防音 &遮像 UVカット 4枚セット プーさん 幅100×長さ135cm×4枚 ニッセン nissen
デザインがかわいいのと、ガラス部分が結露してもわかりにくいのが気に入っています。置くだけでおしゃれな庭になりました。
楽天市場】【2個セット】ソーラー LED ライト ガラスボトル型 ソーラーライト ガーデンライト ランタン ワイヤーライト 照明 室内 室外 明るい おしゃれ イルミネーション ガラス 電球色 防塵 防水 キャンドル 夜間自動点灯 : Smaly(スマリー) 直営店楽天市場】【2個セット】ソーラー LED ライト ガラスボトル型 ソーラーライト ガーデンライト ランタン ワイヤーライト 照明 室内 室外 明るい  おしゃれ イルミネーション ガラス 電球色 防塵 防水 キャンドル 夜間自動点灯 : Smaly(スマリー) 直営店
名入れ 手びねりタンブラー 290ml P-6692 グラス タンブラー 誕生日 記念日 お祝い プレゼント ギフト コップ 名前入り 名前刻印 お酒 実用的 おしゃれ
ソーラーライト ガラスボトル型(2個セット)LEDライト ガラス ガーデンライト 屋外照明 防水 おしゃれ 庭 ソーラー充電式 夜間自動点灯 電気不要 :lj3-21062900111:YoshiYoshi - 通販 - Yahoo!ショッピングソーラーライト ガラスボトル型(2個セット)LEDライト ガラス ガーデンライト 屋外照明 防水 おしゃれ 庭 ソーラー充電式 夜間自動点灯 電気不要  :lj3-21062900111:YoshiYoshi - 通販 - Yahoo!ショッピング
ALAVENTE フロントバンパー ディフレクター スポイラー バンパー ダッジチャレンジャー SXT 2015-2020用 (ブルー)
happysmile 3
めっちゃうすくてペラッペラ。マイメロかわいいのに残念。ふわふわ感一切なし。逆に薄いタオルを求める人には超おすすめ。

クリスマスケーキ 2022 クリスマス ガトーショコラ ギフト 神楽坂 テリーヌショコラ チョコバナナ 限定パッケージ スイーツ プレゼント
LEDソーラーライト 2台セット ガラス ガーデンライト 屋外 防水 照明 おしゃれ 電球色 屋外 防水 ソーラー充電式 自動点灯 電気不要 2-LSOUSOU :s-kg1221-13a-2set:SHOP EAST - 通販 - Yahoo!ショッピングLEDソーラーライト 2台セット ガラス ガーデンライト 屋外 防水 照明 おしゃれ 電球色 屋外 防水 ソーラー充電式 自動点灯 電気不要 2-LSOUSOU  :s-kg1221-13a-2set:SHOP EAST - 通販 - Yahoo!ショッピング
ヒロ 3
レビューを見て購入しましたが、とても後悔しました!本体はプラスチックの様な材質でとても心許ない。ヒーターも性能が悪く、あまり暖かくありません。何よりチャチな作りです!返品をお願いしましたが元払いと送料等を引いた返金と言う事でした。あまりにもバカらしく返品はやめましたが二度とこの会社からは買う事はありません!

鷲見芳美 5
ソファーが布地なので、座り心地がいまいち良くなく、私も主人もおデブなので座る部分が傷むのが心配でした。とても綺麗な優しいブルーで、部屋の雰囲気もよくなり、この凹凸たまらんわ、花が浮かび上がってます。

楽天市場】ソーラーライト LED太陽光 電球色 ガラスボトル ランプ 屋外照明 防水 おしゃれ ガーデンライト 吊り下げ 門灯 飾り 掛け可能 電気代不要 夜間自動点灯 庭 芝生 : Kingyama楽天市場店楽天市場】ソーラーライト LED太陽光 電球色 ガラスボトル ランプ 屋外照明 防水 おしゃれ ガーデンライト 吊り下げ 門灯 飾り 掛け可能 電気代不要  夜間自動点灯 庭 芝生 : Kingyama楽天市場店
フィルム バッジサイズ 37mm 径用 100 枚 缶バッジ マシン 用 素材 単品部品
楽天市場】【39ショップ・ポイント2倍・ポイント2倍】ソーラーライト ガーデンライト 屋外装飾 電球色 LEDガラスボトル型 シンプル 庭照明 太陽光 充電 バッテリー内蔵 インテリア装飾 自動点灯 簡単に設置 電気代ゼロ 自動充電 ガーデニング モザイク 【2個SET ...楽天市場】【39ショップ・ポイント2倍・ポイント2倍】ソーラーライト ガーデンライト 屋外装飾 電球色 LEDガラスボトル型 シンプル 庭照明 太陽光 充電 バッテリー内蔵 インテリア装飾 自動点灯 簡単に設置 電気代ゼロ 自動充電 ガーデニング モザイク 【2個SET ...
長谷川工業 はしご兼用脚立 RHB-09 3尺 ブラック ワンタッチバー付 天板高さ 文房具 チャーム付き眼鏡ケース

xRと出会って変わった人生と出会った技術を書き残すためのGeekなHoloRangerの居場所

本日はUnity調査枠です。

先日GitHub上で公開されているリポジトリから直接Unityパッケージとして機能をインポートする方法を記述しました。

この際にリポジトリのルートが直接パッケージとして読み込める形になっていない場合として任意のパスのフォルダを指定しする方法を紹介しました。

redhologerbera.hatenablog.com

今回はフォルダではなく任意のブランチを指定する方法を紹介します。

〇任意のブランチをUnityパッケージとして導入する。

GitHubでは複数のブランチでプロジェクトが管理されていることがあります。

例えばMicrosoft MixedRealityToolkit GraphicsToolsではmainブランチのほかにpublic/0.4xなどいろいろなブランチが存在しています。

通常何も指定しない場合先日の方法ではdefalutのブランチ(MRGTではmainブランチ)が指定されます。

今回はここを任意のブランチに変更して使用していきます。

今回はpublic/0.4.xのブランチを使用していきます。

package.jsonに次の一行を追加します。

    "com.microsoft.mrtk.graphicstools.unity": "https://github.com/microsoft/MixedReality-GraphicsTools-Unity.git?path=/com.microsoft.mrtk.graphicstools.unity#public/0.4.x",

前回の階層を指定する方法は?path=/(フォルダ名)でしたが今回のブランチを指定する方法は末尾に#(ブランチ名)をつけることで可能になります。

この方法でブランチを選択してインポートできるようになりました。

本日はUnity調査枠です。

今回はGithubのリポジトリから直接パッケージとしてUnityのプロジェクトに導入していきます。

〇環境

・Unity2021.3.5f1

・GitHub

〇経緯と前提

UnityのパッケージではUnity公式非公式問わずに様々なパッケージを入手、使用することができますが、例えばGitHubでオープンソースで開発されているプロジェクトでリリースとして提供されているバージョンではなく、GitHubの最新のリポジトリをパッケージとして導入したいという場合もあります。

筆者の場合Microsoft MixedRealityGraphicsToolsの開発に参加しているということもありリリース版ではなく最新のGitHubリポジトリの機能を使用したい場合があります。

 そういった場合UnityではGitHubのリポジトリ自体からPackageとしてインポートすることができます。

 この方法が可能な条件としてpackage.jsonが存在しUnityパッケージとして機能する必要があります。

 

①UnityプロジェクトのエクスプローラーからPackages/manifest.jesonを開きます。

dependenciesに次の一文を追加します。

 "dependencies": {
    "com.microsoft.mrtk.graphicstools.unity": "https://github.com/microsoft/MixedReality-GraphicsTools-Unity.git",

この名前はMixedReality-GraphicsToolsのpackage.jsonnameがそれに該当します。

github.com

{
  "name": "com.microsoft.mrtk.graphicstools.unity",
  "version": "0.4.14",
  "displayName": "MRTK Graphics Tools",
  "description": "Graphics tools and components for developing Mixed Reality applications in Unity.",
  "msftFeatureCategory": "MRTK3",
  "unity": "2020.3",
  "author": "Microsoft",
  "license": "MIT",
  "repository": {
    "type": "git",
    "url": "https://github.com/microsoft/MixedReality-GraphicsTools-Unity"
  },
  "bugs": {
    "url": "https://github.com/microsoft/MixedReality-GraphicsTools-Unity/issues"
  },

urlはリポジトリをクローンする際のHTTPSを指定します。

③URLの末尾に次の行を追加します。

?path=/com.microsoft.mrtk.graphicstools.unity

これはpackage.jsonがリポジトリの直下に存在する場合は必要ないですが、今回のMRGTの場合リポジトリのcom.microsoft.mrtk.graphicstools.unityフォルダにpackage.jsonがあり、一つ下の階層を指定する必要があります。

これを行うためにはHTTPS?path=/(フォルダ名)を使用します。

これによってUnityのプロジェクトを開いた際にパッケージが導入されます。

以上でGitHubリポジトリからUnityパッケージとしてインポートできました。

タイガー魔法瓶 保温 卓上 ステンレス エアー ポット とら~ず 3.0L MAA-C300-XC シルバー

本日はMRGT調査枠です。

前回に引き続きMixedRealityGraphicsTools StandardShader全機能を解説していきます。

前回はCullModeの実装を見ていきました。

Huawei Mediapad M5 8.4 ケース メディアパッド m5 8 カバー SHT-W09 AL09 8.4インチ 3点セット 保護フィルム タッチペン おまけ フィルム スタンドケース スタ

本日はAlbedoの処理を追っていきます。

〇Albedo

Albedoは最も基本的な設定になります。

ここではテクスチャと色を指定することができます。

プロパティ上は冒頭に記載されている_Color_MainTexで定義されています。

Shader "Graphics Tools/Standard"
{
    Properties
    {
        // Main maps.
        _Color("Color", Color) = (1.0, 1.0, 1.0, 1.0)
        _MainTex("Albedo", 2D) = "white" {}

また実装ではPixelShaderの最初期に処理が行われています。

MRGTShaderのPixelShaderでは最初にテクスチャ関係の処理が行われています。

half4 PixelStage(Varyings input, bool facing : SV_IsFrontFace) : SV_Target
{
  ・・・
#if defined(_TRIPLANAR_MAPPING)
    // Calculate triplanar uvs and apply texture scale and offset values like TRANSFORM_TEX.
    half3 triplanarBlend = pow(abs(input.triplanarNormal), _TriplanarMappingBlendSharpness);
    triplanarBlend /= dot(triplanarBlend, half3(1.0h, 1.0h, 1.0h));
    float2 uvX = input.triplanarPosition.zy * _MainTex_ST.xy + _MainTex_ST.zw;
    float2 uvY = input.triplanarPosition.xz * _MainTex_ST.xy + _MainTex_ST.zw;
    float2 uvZ = input.triplanarPosition.xy * _MainTex_ST.xy + _MainTex_ST.zw;
  ・・・
#endif
// Texturing.
#if defined(_DISABLE_ALBEDO_MAP)
    half4 albedo = half4(1.0h, 1.0h, 1.0h, 1.0h);
#else
#if defined(_TRIPLANAR_MAPPING)
#if defined(_URP)
    half4 albedo = SAMPLE_TEXTURE2D(_MainTex, sampler_MainTex, uvX) * triplanarBlend.x +
                   SAMPLE_TEXTURE2D(_MainTex, sampler_MainTex, uvY) * triplanarBlend.y +
                   SAMPLE_TEXTURE2D(_MainTex, sampler_MainTex, uvZ) * triplanarBlend.z;
#else
    half4 albedo = tex2D(_MainTex, uvX) * triplanarBlend.x +
                   tex2D(_MainTex, uvY) * triplanarBlend.y +
                   tex2D(_MainTex, uvZ) * triplanarBlend.z;
#endif
#else
   ・・・
#if defined(_URP)
    half4 albedo = SAMPLE_TEXTURE2D(_MainTex, sampler_MainTex, input.uv);
#else
    half4 albedo = tex2D(_MainTex, input.uv);
#endif
#endif
#endif
#endif

ここでは機能ごとに分かれていますが基本的な処理は次のようになります。

#if defined(_URP)
    half4 albedo = SAMPLE_TEXTURE2D(_MainTex, sampler_MainTex, input.uv);
#else
    half4 albedo = tex2D(_MainTex, input.uv);
#endif

URPの場合とビルドインの場合で処理が分岐していますが、どちらもサンプリングを行っているだけです。

これらのサンプラーはGraphicsToolsStandardInputで定義されています。

#if defined(_URP)
TEXTURE2D(_MainTex);
SAMPLER(sampler_MainTex);
#endif
#else
sampler2D _MainTex;

URPではSAMPLERが使用できるため最適化されています。

half4 albedoは最終出力へ出力されております。

本日は以上です。

このあたりは基礎的なものですね。

本日はBlenderモデリング枠です。

今回はBlenderでNゴンを表示する方法を紹介します。

〇Nゴンとは?

Nゴンとはメッシュの形状を指す言葉です。

3DCGは様々な拡張子があり、様々な表現が行われていますが、共通して頂点と3つの頂点をもとに構成される面であるメッシュで構成されています。

この三角形のメッシュをポリゴンと呼びます。

しかしBlenderでは3つ以上の頂点をもとにメッシュを作成することができます。

上記の例では32個の頂点で一つのメッシュが形成されています。

このように3つ以上の頂点で構成されるメッシュのことをNゴンと呼んでいます。

 Blenderだけで使用する場合はまだよいのですが、NゴンはBlenderからエクスポートされた場合自動でポリゴンへ変換されます。

 この際にメッシュが破断してしまうことがあります。また一部のアドオンなどではメッシュ形状に依存しているものがあり、Nゴンは許容するかNゴンを作らないように作成するかはモデラーが後先のことを考えて作成する必要があります。

〇Nゴンを検出する

今回はアドオンの関係でNゴンが許容できず修正する必要がありました。

具体的にはHairToolで髪を作成する際に4つの頂点で構成されるメッシュである必要がありました。

redhologerbera.hatenablog.com

redhologerbera.hatenablog.com

HairToolを使用するためにはメッシュを四角形にする必要があります。

これは三角面を四角面にを選択して半自動的にメッシュを修正します。

ですが単純に行っては一部に三角形やNゴンが生じます。

この先は手動で修正する必要がありますがここからNゴンの検出を行います。

ここからは特徴で全選択から面の辺数を選択します。

メニューから頂点数を今回発見したいNゴンの数にします。

ここで表示されている面が今回では四角形以外のメッシュになります。

5角形のNゴンを検出したい場合は頂点数を5に設定します。

以上でNゴンを検出できました。

本日はグラフィック調査枠です。

〇RenderDocとは?

RenderDocはオープンソースで開発、提供されている、GPU上で実行されている処理を見ることができるソフトウェアになります。

〇RenderDocを使用してUnityアプリのデバッグを行う。

今回はOculusLinkで接続したPCVR用のアプリケーションのデバッグを行います。

今回はもともとMetaQuest単体で動かすために開発していたソフトウェアを急遽PCVRでアプリケーションを実行したところ、一部のオブジェクトが描画されないという問題が発生しました。

 今回はなぜ描画がされていないのかデバッグを行いました。

 UnityではEditor自体がRenderDocによるデバッグをサポートしているためRenderDocがインストールされているPC環境ではGameウィンドウ、もしくはSceneウィンドウからキャプチャを行うことができました。

 Unityで開発したアプリケーションにはその機能はないため、RenderDoc経由でアプリケーションを起動する必要があります。

〇環境

・Windows 11

・PCVR(Desktop)向けにビルドしたUnityアプリケーション

・RenderDoc

〇手順

①RenderDocを起動します。

前述のとおりデバッグを行うアプリケーションはRenderDoc経由で起動する必要があります。

②Launch Applicationタブを開きます。

Executable Pathの右側アイコンを選択します。

④起動したいUnityアプリのexeファイルを選択します。

⑤Pathが入ったことを確認してLaunchを選択します。

以上でアプリが起動します。

RenderDoc経由で起動した場合左上部にデバッグログが表示されるようになっています。

キャプチャをとるためにはF12キーを選択します。

〇ピクセル単位のデバッグ

今回はあるピクセルにおいてどのような処理が実行されているのかを調べます。

Texture Viewerで任意のピクセルを右クリックします。

これによってPixel Contextにピクセル単位の表示が行われます。

Pixel Context下部のHistoryを選択することでそのピクセルで行われているイベントを見ることができます。

画像の例では4つのイベントが走っていることがわかります。

各イベントをダブルクリックすることでそのイベントへと飛ぶことができます。

Pixel Contextを使用することでそのピクセルで実行されているイベントと描画されるRGBAを見ることができます。

 これによってより描画がおかしい場所などデバッグを行いやすくなっています。

本日は以上です。

レンガ タイル ブリックタイル 軽量レンガ ブリック ブルックリン アンティークレンガ(コアブリック イエロー(18) ケース販売)

本日はMRGT調査枠です。

前回に引き続きMixedRealityGraphicsTools StandardShader全機能を解説していきます。

前回はRenderingModeの実装を見ていきました。

redhologerbera.hatenablog.com

redhologerbera.hatenablog.com

redhologerbera.hatenablog.com

redhologerbera.hatenablog.com

今回はCullModeを見ていきます。

〇CullModeとは?

CullModeはカリングを指し、もともと不要なものを取り除くという意味があります。

 Shaderではメッシュの裏面、表面のどちらかを描画するかを指定するパラメータになります。

 CullModeの意味に合わせると『メッシュの表、裏どちらを不要な描画として描画しないか』になります。

デフォルトではBackが指定されており、この状態ではメッシュの裏面が描画されなくなっています。

CullMode=Back

この場合メッシュの表面のみが描画され、Unityプリミティブキューブの場合では近づいたときに見えるキューブの内側は描画されていないことがわかります。

反対にfrontでは面の表面がカリングされ、裏面が描画されます。

CullMode=front

もう一つOffというモードがあります。

これはカリングを無効(=カリングしない)モードでこの場合メッシュの両面が描画されます。

通常の不透明オブジェクトの場合デフォルトのBackで問題なく表示されますが、例えば次の画像の髪のように板ポリゴンで構成されているメッシュの場合見た目が悪くなることがあります。

オフにすることで両面が描画され、ある程度違和感のない見た目が実現できます。

当然Offにすることで描画負荷は上がってしまいますが、MRTKのシェーダーの場合任意に切り替えることもできるので、裏面が見えないようなオブジェクトをポリゴンで再現する場合とCullModeで対応する場合で比較した場合ほとんどの場合はCullModeで両面描画するほうがパフォーマンスもよくなると思うので、便利な機能です。

〇実装

カリングはShaderLab内で次のように定義します。

Cull Off
Cull Front
Cull Back

Graphicstools StandardShaderでは次のように実装されています。

  // Default pass (only pass outside of the editor).
        Pass
        {
            Name "Main"
            ・・・
            Cull[_CullMode]
            ・・・
            HLSLPROGRAM
   ・・・
            ENDHLSL
        }

_CullModeはPropetiesブロックで定義されています。

        [Enum(UnityEngine.Rendering.CullMode)] _CullMode("Cull Mode", Float) = 2                             // "Back"

UnityEngine.Rendering.CullModeはUnityで提供されるEnum型のクラスです。

docs.unity3d.com

冒頭で紹介した通りBack、Front、Offが提供されておりそれぞれ値を渡せるよういなっています。

本日は以上です。

本日はUnityのトラブルシューティング枠です。

本日まで3日ほど筆者は所属している会社の方で展示会に出展しておりました。

LM-BE25P5 [Panasonic パナソニック] 録画用 BD-RE 1-2倍速 25GB 5枚 LMBE25P5

今回はPCVR(OculusLink)向けにアプリケーションを開発したのですが、作成したexeファイルをPCで実行する際にセキュリティスキャンが始まり起動できない問題がありましたので今回は解消した方法を残します。

〇問題

冒頭で紹介したようにUnityで出力された.exeファイルを実行時にセキュリティスキャンが行われ、いつまでもアプリが起動しない問題がありました。

この問題を解消するためには一時的にWindowsのセキュリティを解除するウことを行いました。

これを行うためにWindowsの[設定]アプリを開きます。[更新とセキュリティ]を選択します。

[Windoiwsセキュリティ]を選択し[アプリとブラウザーの制御]を選択します。

この設定では実行するアプリやWebブラウザーでのウィルスなどのセキュリティをチェックしています。

今回は筆者自身が作成したアプリケーションであるため一時的にセキュリティを解除しています。

次に[評価ベースの保護設定]を選択します。

最後に[望ましくない可能性のあるアプリをブロック]をオフに設定します。

この設定はデフォルトではオンになっているものです。

この操作によってアプリ起動時のブロックが発生しなくなります。

この状態で[管理者権限で実行]を利用してアプリケーションを起動することでループから抜け出しアプリケーションが起動します。

本日は簡単なトラブルシューティングになりました。

なお、セキュリティの問題からアプリ終了時にはセキュリティによる保護を再度確認し、有効にする必要があります。