qwt__raster__data_8cpp-source.html

来自「QWT5.01用于Qt开发的二维图形库程序」· HTML 代码 · 共 388 行 · 第 1/3 页

HTML
388
字号
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html><head><meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1"><title>Qwt User&apos;s Guide: qwt_raster_data.cpp Source File</title><link href="doxygen.css" rel="stylesheet" type="text/css"><link href="tabs.css" rel="stylesheet" type="text/css"></head><body><!-- Generated by Doxygen 1.4.6 --><div class="tabs">  <ul>    <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>    <li><a href="classes.html"><span>Classes</span></a></li>    <li id="current"><a href="files.html"><span>Files</span></a></li>    <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>  </ul></div><h1>qwt_raster_data.cpp</h1><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/* -*- mode: C++ ; c-file-style: "stroustrup" -*- *****************************</span><a name="l00002"></a>00002 <span class="comment"> * Qwt Widget Library</span><a name="l00003"></a>00003 <span class="comment"> * Copyright (C) 1997   Josef Wilgen</span><a name="l00004"></a>00004 <span class="comment"> * Copyright (C) 2002   Uwe Rathmann</span><a name="l00005"></a>00005 <span class="comment"> *</span><a name="l00006"></a>00006 <span class="comment"> * This library is free software; you can redistribute it and/or</span><a name="l00007"></a>00007 <span class="comment"> * modify it under the terms of the Qwt License, Version 1.0</span><a name="l00008"></a>00008 <span class="comment"> *****************************************************************************/</span><a name="l00009"></a>00009 <a name="l00010"></a>00010 <span class="preprocessor">#include "qwt_raster_data.h"</span><a name="l00011"></a>00011 <a name="l00012"></a>00012 <span class="keyword">class </span>QwtRasterData::Contour3DPoint<a name="l00013"></a>00013 {<a name="l00014"></a>00014 <span class="keyword">public</span>:<a name="l00015"></a>00015     <span class="keyword">inline</span> <span class="keywordtype">void</span> setPos(<span class="keywordtype">double</span> x, <span class="keywordtype">double</span> y)<a name="l00016"></a>00016     {<a name="l00017"></a>00017         d_x = x;<a name="l00018"></a>00018         d_y = y;<a name="l00019"></a>00019     }<a name="l00020"></a>00020 <a name="l00021"></a>00021     <span class="keyword">inline</span> QwtDoublePoint pos()<span class="keyword"> const</span><a name="l00022"></a>00022 <span class="keyword">    </span>{<a name="l00023"></a>00023         <span class="keywordflow">return</span> QwtDoublePoint(d_x, d_y);<a name="l00024"></a>00024     }<a name="l00025"></a>00025 <a name="l00026"></a>00026     <span class="keyword">inline</span> <span class="keywordtype">void</span> setX(<span class="keywordtype">double</span> x) { d_x = x; }<a name="l00027"></a>00027     <span class="keyword">inline</span> <span class="keywordtype">void</span> setY(<span class="keywordtype">double</span> y) { d_y = y; }<a name="l00028"></a>00028     <span class="keyword">inline</span> <span class="keywordtype">void</span> setZ(<span class="keywordtype">double</span> z) { d_z = z; }<a name="l00029"></a>00029 <a name="l00030"></a>00030     <span class="keyword">inline</span> <span class="keywordtype">double</span> x()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> d_x; }<a name="l00031"></a>00031     <span class="keyword">inline</span> <span class="keywordtype">double</span> y()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> d_y; }<a name="l00032"></a>00032     <span class="keyword">inline</span> <span class="keywordtype">double</span> z()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> d_z; }<a name="l00033"></a>00033 <a name="l00034"></a>00034 <span class="keyword">private</span>:<a name="l00035"></a>00035     <span class="keywordtype">double</span> d_x;<a name="l00036"></a>00036     <span class="keywordtype">double</span> d_y;<a name="l00037"></a>00037     <span class="keywordtype">double</span> d_z;<a name="l00038"></a>00038 };<a name="l00039"></a>00039 <a name="l00040"></a>00040 <span class="keyword">class </span>QwtRasterData::ContourPlane<a name="l00041"></a>00041 {<a name="l00042"></a>00042 <span class="keyword">public</span>:<a name="l00043"></a>00043     <span class="keyword">inline</span> ContourPlane(<span class="keywordtype">double</span> z):<a name="l00044"></a>00044         d_z(z)<a name="l00045"></a>00045     {<a name="l00046"></a>00046     }<a name="l00047"></a>00047 <a name="l00048"></a>00048     <span class="keyword">inline</span> <span class="keywordtype">bool</span> intersect(<span class="keyword">const</span> Contour3DPoint vertex[3],<a name="l00049"></a>00049         QwtDoublePoint line[2], <span class="keywordtype">bool</span> ignoreOnPlane) <span class="keyword">const</span>;<a name="l00050"></a>00050 <a name="l00051"></a>00051     <span class="keyword">inline</span> <span class="keywordtype">double</span> z()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> d_z; }<a name="l00052"></a>00052 <a name="l00053"></a>00053 <span class="keyword">private</span>:<a name="l00054"></a>00054     <span class="keyword">inline</span> <span class="keywordtype">int</span> compare(<span class="keywordtype">double</span> z) <span class="keyword">const</span>;<a name="l00055"></a>00055     <span class="keyword">inline</span> QwtDoublePoint intersection(<a name="l00056"></a>00056         <span class="keyword">const</span> Contour3DPoint&amp; p1, <span class="keyword">const</span> Contour3DPoint &amp;p2) <span class="keyword">const</span>;<a name="l00057"></a>00057 <a name="l00058"></a>00058     <span class="keywordtype">double</span> d_z;<a name="l00059"></a>00059 };<a name="l00060"></a>00060 <a name="l00061"></a>00061 <span class="keyword">inline</span> <span class="keywordtype">bool</span> QwtRasterData::ContourPlane::intersect(<a name="l00062"></a>00062     <span class="keyword">const</span> Contour3DPoint vertex[3], QwtDoublePoint line[2],<a name="l00063"></a>00063     <span class="keywordtype">bool</span> ignoreOnPlane)<span class="keyword"> const</span><a name="l00064"></a>00064 <span class="keyword"></span>{<a name="l00065"></a>00065     <span class="keywordtype">bool</span> found = <span class="keyword">true</span>;<a name="l00066"></a>00066 <a name="l00067"></a>00067     <span class="comment">// Are the vertices below (-1), on (0) or above (1) the plan ?</span><a name="l00068"></a>00068     <span class="keyword">const</span> <span class="keywordtype">int</span> eq1 = compare(vertex[0].z());<a name="l00069"></a>00069     <span class="keyword">const</span> <span class="keywordtype">int</span> eq2 = compare(vertex[1].z());<a name="l00070"></a>00070     <span class="keyword">const</span> <span class="keywordtype">int</span> eq3 = compare(vertex[2].z());<a name="l00071"></a>00071 <a name="l00072"></a>00072     <span class="comment">/*</span><a name="l00073"></a>00073 <span class="comment">        (a) All the vertices lie below the contour level.</span><a name="l00074"></a>00074 <span class="comment">        (b) Two vertices lie below and one on the contour level.</span><a name="l00075"></a>00075 <span class="comment">        (c) Two vertices lie below and one above the contour level.</span><a name="l00076"></a>00076 <span class="comment">        (d) One vertex lies below and two on the contour level.</span><a name="l00077"></a>00077 <span class="comment">        (e) One vertex lies below, one on and one above the contour level.</span><a name="l00078"></a>00078 <span class="comment">        (f) One vertex lies below and two above the contour level.</span><a name="l00079"></a>00079 <span class="comment">        (g) Three vertices lie on the contour level.</span><a name="l00080"></a>00080 <span class="comment">        (h) Two vertices lie on and one above the contour level.</span><a name="l00081"></a>00081 <span class="comment">        (i) One vertex lies on and two above the contour level.</span><a name="l00082"></a>00082 <span class="comment">        (j) All the vertices lie above the contour level.</span><a name="l00083"></a>00083 <span class="comment">     */</span><a name="l00084"></a>00084 <a name="l00085"></a>00085     <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">int</span> tab[3][3][3] =<a name="l00086"></a>00086     {<a name="l00087"></a>00087         <span class="comment">// jump table to avoid nested case statements</span><a name="l00088"></a>00088         { { 0, 0, 8 }, { 0, 2, 5 }, { 7, 6, 9 } },<a name="l00089"></a>00089         { { 0, 3, 4 }, { 1, 10, 1 }, { 4, 3, 0 } },<a name="l00090"></a>00090         { { 9, 6, 7 }, { 5, 2, 0 }, { 8, 0, 0 } }<a name="l00091"></a>00091     };<a name="l00092"></a>00092 <a name="l00093"></a>00093     <span class="keyword">const</span> <span class="keywordtype">int</span> edgeType = tab[eq1+1][eq2+1][eq3+1];<a name="l00094"></a>00094     <span class="keywordflow">switch</span> (edgeType)  <a name="l00095"></a>00095     {<a name="l00096"></a>00096         <span class="keywordflow">case</span> 1:<a name="l00097"></a>00097             <span class="comment">// d(0,0,-1), h(0,0,1)</span><a name="l00098"></a>00098             line[0] = vertex[0].pos();<a name="l00099"></a>00099             line[1] = vertex[1].pos();<a name="l00100"></a>00100             <span class="keywordflow">break</span>;<a name="l00101"></a>00101         <span class="keywordflow">case</span> 2:<a name="l00102"></a>00102             <span class="comment">// d(-1,0,0), h(1,0,0)</span><a name="l00103"></a>00103             line[0] = vertex[1].pos();<a name="l00104"></a>00104             line[1] = vertex[2].pos();<a name="l00105"></a>00105             <span class="keywordflow">break</span>;<a name="l00106"></a>00106         <span class="keywordflow">case</span> 3:<a name="l00107"></a>00107             <span class="comment">// d(0,-1,0), h(0,1,0)</span><a name="l00108"></a>00108             line[0] = vertex[2].pos();<a name="l00109"></a>00109             line[1] = vertex[0].pos();<a name="l00110"></a>00110             <span class="keywordflow">break</span>;<a name="l00111"></a>00111         <span class="keywordflow">case</span> 4:<a name="l00112"></a>00112             <span class="comment">// e(0,-1,1), e(0,1,-1)</span><a name="l00113"></a>00113             line[0] = vertex[0].pos();<a name="l00114"></a>00114             line[1] = intersection(vertex[1], vertex[2]);<a name="l00115"></a>00115             <span class="keywordflow">break</span>;<a name="l00116"></a>00116         <span class="keywordflow">case</span> 5:

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?