`
hereson
  • 浏览: 1468730 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

Papervision3D の BitmapMaterial と MovieMaterial の使用

    博客分类:
  • Pv3d
阅读更多
package {

  import flash.display.*;
  import flash.events.*;
  import flash.geom.*;
  import flash.text.*;

  import org.papervision3d.scenes.*;
  import org.papervision3d.objects.*;
  import org.papervision3d.cameras.*;
  import org.papervision3d.materials.*;

  [SWF(width="400", height="400", backgroundColor="#000000", frameRate="30")]

  // BitmapMaterial と MovieMaterial (テキスト表示) のサンプル
  public class MaterialSample extends Sprite {

    private var container : Sprite;
    private var scene     : Scene3D;
    private var camera    : Camera3D;
    private var rootNode  : DisplayObject3D;

    private var obj:Array = new Array();

    // 3Dオブジェクト踊らせ用パラメータ
    private var valx    : Number = 0;
    private var valy    : Number = 0;

    // Bitmap
    private var bitmapdata:BitmapData;

    // Text
    private var text:TextField;
    private var material:MovieMaterial

    public function MaterialSample():void {

      // 画面いっぱいに表示(縦横比無視)したいときはコレを使う
      // stage.scaleMode = StageScaleMode.EXACT_FIT;

      // リサイズに対応(swfをブラウザで直接ひらいているときとか)
      stage.addEventListener(Event.RESIZE, onStageResize);

      // 定期的にイベント発生
      addEventListener(Event.ENTER_FRAME, myLoopEvent);

      // マウスクリックでイベント発生
      stage.addEventListener(MouseEvent.CLICK, myClick);

      // 表示用の Sprite オブジェクトを生成
      container = new Sprite();
      container.x = 400 / 2; // at center : swf width  = 400
      container.y = 400 / 2; // at center : swf height = 400
      addChild(container);

      // シーンオブジェクトを作る
      scene = new Scene3D(container);

      // カメラオブジェクトを作る
      camera = new Camera3D();
      camera.z = -200;
      camera.focus = 500;
      camera.zoom = 1;

      // ルートノードを作る
      rootNode = new DisplayObject3D();
      scene.addChild(rootNode);

      // いろんな3Dオブジェクトを作ってみて、配列に入れておく
      obj.push(createWireframePlane());
      obj.push(createBitmapPlane());
      obj.push(createTextPlane());
      obj.push(createTextCube());

      // 3Dオブジェクトをルートノードに追加
      for(var i:int; i<obj.length; i++){
        rootNode.addChild(obj[i]);
      }
    }

    private function createWireframePlane():DisplayObject3D {

      var material:WireframeMaterial = new WireframeMaterial();
      material.oneSide = false;
      material.lineColor = 0x00FF00;
      material.lineAlpha = 1;

      var planeSize:int = 200;
      var segment:int = 2;

      var plane:Plane = new Plane(
        material, planeSize, planeSize, segment, segment);
      plane.x =   0;
      plane.y =  180;
      plane.z =   0;
      return plane;
    }

    private function createBitmapPlane():DisplayObject3D {

      var bd:BitmapData = new BitmapData(100, 100, false);
      this.bitmapdata = bd; // using this
      var material:BitmapMaterial = new BitmapMaterial(bd);

      material.oneSide = false;
      material.lineColor = 0x00FF00;
      material.lineAlpha = 1;

      var planeSize:int = 200;
      var segment:int = 2;

      var plane:Plane = new Plane(
        material, planeSize, planeSize, segment, segment);
      plane.x =  -180;
      plane.y =  0;
      plane.z =  0;
      return plane;
    }

    private function createTextPlane():DisplayObject3D {

      var asset:MovieClip = createMovieClip();
      var transparent:Boolean = true;
      var initObject:Object = {animated:true, doubleSided:true};

      var material:MovieMaterial = new MovieMaterial(asset, transparent, initObject);
      this.material = material; // using this

      var planeSize:int = 200;
      var segment:int = 2;

      var plane:Plane = new Plane(
        material, planeSize, planeSize, segment, segment);
      plane.x =  180;
      plane.y =  0;
      plane.z =  0;
      return plane;
    }

    private function createTextCube():DisplayObject3D {

      var planeSize:int = 200;
      var segment:int = 2;

      // using this
      var cube:Cube = new Cube(
        this.material, planeSize, planeSize, planeSize, segment, segment, segment);
      cube.x =  0;
      cube.y =  0;
      cube.z =  0;
      return cube;
    }

    private function createMovieClip():MovieClip {
      var mc:MovieClip = new MovieClip();
      var text:TextField = createTextField();
      text.text = getPropertiesString(mc);
      mc.addChild(text);
      this.text = text; // using this
      return mc;
    }

    private static function createTextField():TextField{

      // 表示メッセージのスタイル
      var format:TextFormat = new TextFormat();
      format.bold = false;
      format.italic = false;
      format.size = 10;
      format.underline = false;
      format.font = "_等幅";

      // 表示メッセージ
      var text:TextField = new TextField();
      text.autoSize = TextFieldAutoSize.LEFT;
      text.selectable = false;
      text.setTextFormat(format);
      text.background = true;
      text.backgroundColor = 0x000000;
      text.border = false;
      text.borderColor = 0xFFFFFF;
      text.textColor = 0xFFFFFF;

      return text;
    }

    // 最初だけこんなの表示してみる
    private static function getPropertiesString(mc:MovieClip):String {
        var str:String = ""
        + "currentFrame: " + mc.currentFrame + "\n"
        + "currentLabel: " + mc.currentLabel + "\n"
        + "currentScene: " + mc.currentScene + "\n"
        + "framesLoaded: " + mc.framesLoaded + "\n"
        + "totalFrames: " + mc.totalFrames + "\n"
        + "trackAsMenu: " + mc.trackAsMenu + "\n";
      return str;
    }

    private function myClick(event:MouseEvent):void {

      // update Bitmap
      // Math.random: (0 <= n < 1)
      var x:int = (int)(Math.random() * 100);
      var y:int = (int)(Math.random() * 100);
      // bitmapdata.setPixel(x, y, 0xFF0000);
      var rect:Rectangle = new Rectangle(x, y, 20, 20);
      bitmapdata.fillRect(rect, 0xFF0000);

      // update Text
      text.border = !text.border; // ワクを付けたり消したり
      text.background = !text.background; // 背景を付けたり消したり

      text.text = "マウスを\nクリックした位置:\nLocation(" + container.mouseX + "," + container.mouseY + ")";
      material.updateBitmap(); // 更新を通知
      //scene.renderCamera(camera);
    }

    private function myLoopEvent(event:Event):void {

      valx += container.mouseX / 50;
      valy += container.mouseY / 50;

      for(var i:int; i<obj.length; i++){
        obj[i].rotationY = valx;
        obj[i].rotationX = valy;
      }

      scene.renderCamera(camera);
    }

    private function onStageResize(event:Event):void {
      container.x = stage.stageWidth  / 2;
      container.y = stage.stageHeight / 2;
    }
   
  }
}
分享到:
评论

相关推荐

    学习PaperVision3D随行笔记,基础知识

    ### PaperVision3D基础知识与建模技术解析 #### 基础概念介绍 PaperVision3D(PV3D)是一款强大的3D图形引擎,专为Adobe Flash平台设计,旨在简化三维场景的创建与渲染。PV3D的核心在于其对3D场景、相机、渲染引擎...

    PV3D中文手册

    在Papervision3D(PV3D)中,Cube(立方体)是最基本的3D对象之一。它通常用于构建更复杂的3D场景。Cube可以通过设置其宽度、高度和深度来创建。 #### 二、MovieMaterial影片材质 **MovieMaterial**是一种特殊的...

    支持pyramid2.x的kotti web代码

    Kotti 是一个基于 Pyramid 框架的 Python 内容管理系统(CMS),适合用来搭建中小型网站、文档库、企业展示平台、知识库等需要灵活内容结构和权限模型的项目。它本身更像一个可以二次开发的 CMS 框架,比 WordPress、Drupal 这类“一装就用”的系统更倾向于开发者定制和扩展。 这是支持pyramid2.x版本的kotti! tar -xzvf kotti1.0.tar.gz 解压缩 进入目录执行 pip install -e . 来安装, 然后执行pserve app.ini 启动。 用浏览器浏览127.0.0.1:5000 即可浏览。 用户名admin ,口令qwerty

    cmd-bat-批处理-脚本-hello world.zip

    cmd-bat-批处理-脚本-hello world.zip

    知识付费系统自动采集V3.0 跳转不卡顿+搭建教程

    知识付费系统自动采集V3.0 跳转不卡顿+搭建教程,不和外面的一样跳转卡顿,这个跳转不卡顿,支持三级分销。

    基于Matlab实现图像形状纹理颜色特征提取

    在Matlab环境下,对图像进行特征提取时,主要涵盖形状、纹理以及颜色这三大关键特征。其中,对于纹理特征的提取,采用灰度梯度共生矩阵这一方法来实现。通过灰度梯度共生矩阵,可以有效地捕捉图像中像素灰度值之间在不同方向和距离上的相互关系,进而量化地反映出图像的纹理特性,为后续的图像分析、分类等任务提供重要的纹理信息依据。

    实证数据-2010-2023年上市公司-管理层情感语调数据-社科经管.rar

    该数据集为2010-2023年中国A股上市公司管理层情感语调的年度面板数据,覆盖45,320条样本,数据源自年报及半年报的"管理层讨论与分析"部分。通过构建中文金融情感词典(融合《知网情感分析用词典》与L&M金融词汇表),采用文本分析方法计算情感语调指标,包括:正面/负面词汇数量、文本相似度、情感语调1((积极词-消极词)/总词数)和情感语调2((积极词-消极词)/(积极词+消极词))。同时包含盈利预测偏差、审计意见类型等衍生指标,可用于研究信息披露质量、市场反应及代理问题。该数据复刻了《管理世界》《财经研究》等期刊的变量构建方法,被应用于分析语调操纵对债券市场的影响,学术常用度与稀缺度较高。

    cmd-bat-批处理-脚本-FTIME.zip

    cmd-bat-批处理-脚本-FTIME.zip

    1747829038637.png

    1747829038637.png

    2025年自动化X光检查机项目大数据研究报告.docx

    2025年自动化X光检查机项目大数据研究报告.docx

    基于Logisim的原码与补码一位乘法器设计

    在计算机组成原理课程设计中,我全程跟随老师的指导,独立完成了以下两项任务:一是利用Logisim软件进行原码一位乘法器的仿真设计,通过逐步搭建电路、配置逻辑单元,实现了原码乘法运算的完整流程,深入理解了原码乘法的原理和实现机制;二是完成了补码一位乘法器的Logisim仿真,同样按照老师讲解的步骤,精心设计电路,确保补码乘法运算的正确性,进一步掌握了补码乘法的运算规则和电路实现方法。通过这两个项目,我不仅巩固了理论知识,还提升了动手实践能力和逻辑思维能力。

    cmd-bat-批处理-脚本-msvc2017.zip

    cmd-bat-批处理-脚本-msvc2017.zip

    cmd-bat-批处理-脚本-virtualcam-install.zip

    cmd-bat-批处理-脚本-virtualcam-install.zip

    二十四节气之立秋介绍.pptx

    二十四节气之立秋介绍.pptx

    cmd-bat-批处理-脚本-shift.zip

    cmd-bat-批处理-脚本-shift.zip

    二十四节气之小雪介绍.pptx

    二十四节气之小雪介绍.pptx

    java、SpringBoot面试专题,6页面试题

    java、SpringBoot面试专题,6页面试题

    cmd-bat-批处理-脚本-GenerateUnionWinMD.zip

    cmd-bat-批处理-脚本-GenerateUnionWinMD.zip

    二十四节气之大暑节气.pptx

    二十四节气之大暑节气.pptx

    python实现五子棋游戏源码

    python实现五子棋游戏源码

Global site tag (gtag.js) - Google Analytics