Витяг координат з файлу autocad dxf з допомогою функції explode php

Розбиття рядка, отриманої з MySQL за допомогою explode()

Функція отримує малі координати з бази даних, потім рядок розбивається за допомогою explode php, після чого imagepolygon() малює нам багатокутники.

$coordinates[$key] = explode(‘;’, $coordinates_string);
imagepolygon($im, $coordinates[$key], $polygon_arrays_count[$key] , $black);

Для даного прикладу картинка створена у форматі imagepng base64_encode, але ви можете зберегти зображення в jpg або png.

Тепер можна вивести зображення в браузері:

$image_array = array($implode_coordinates_db, $width, $height);
$image_base64 = image_create($image_array);
$image_src=’дані:image/png;base64,’.$image_base64;
echo “<img src='”.$image_src.”‘>”;

Background картинки буде виглядати так:

Якщо є можливість застосувати вбудовані функції замість регулярних виразів, то процес виконання програми буде займати трохи менше часу, тому завжди має сенс спочатку спробувати досягти поставленої мети з допомогою готових рішень в php.

Весь код:

$content = file_get_contents(‘stairs.dxf’);
$entities = strchr($content, “ENTITIES”);
$endsec = strchr($entities, “ENDSEC”, true);
$entitie_string = $endsec;

$entities_array = array(“LWPOLYLINE”);

$lastPos = 0;
$positions_entities = array();
foreach($entities_array as $key_needle =>$entitie){
while (($lastPos = strpos($entitie_string, $entitie, $lastPos))!== false) {
$positions_entities[$lastPos] = $entitie;
$lastPos = $lastPos + strlen($entitie);
}
}
$array_keys_positions = array_keys($positions_entities);
$sizeof_array_positions = sizeof($array_keys_positions);
for($i=0; $i< $sizeof_array_positions; $i++){
if(isset($array_keys_positions[$i+1])){
$entities_string_array[$positions_entities[$array_keys_positions[$i]]][$array_keys_positions[$i]] = substr($entitie_string, $array_keys_positions[$i], $array_keys_positions[$i+1] – $array_keys_positions[$i] );
}
else{
$entities_string_array[$positions_entities[$array_keys_positions[$i]]][$array_keys_positions[$i]] = substr($entitie_string, $array_keys_positions[$i] );
}
}

foreach( $entities_string_array as $key_ent =>$value_ent){
foreach( $value_ent as $key_val =>$value_e ){
$explode_value_e[$key_ent][$key_val] = explode(PHP_EOL, $value_e);
}
}

$lwpolyline_array = $explode_value_e[“LWPOLYLINE”];
$k = 0;
foreach( $lwpolyline_array as $lw_key => $explode_key ){
foreach( $explode_key as $key => $lwpolyline_value){
if( $lwpolyline_value == ’10’ ){
$coordinates[$k][] = $coordinates_db[] = $coordinates_x[] = (float)$explode_key[$key+1];
}else if( $lwpolyline_value == ’20’ ){
$coordinates[$k][] = $coordinates_db[] = $coordinates_y[] = (float)$explode_key[$key+1];
}
}
$implode_coordinates_db[$k] = implode(‘;’,$coordinates_db);
$k++;
}
$width = max($coordinates_x) – min($coordinates_x);
$height = max($coordinates_y) – min($coordinates_y);

function image_create( $image_array ){
$implode_coordinates = $image_array[0];
$width = $image_array[1];
$height = $image_array[2];
$im = imagecreatetruecolor($width+1, $height+1);
$white=imagecolorallocate($im,255,255,255);
$black = imagecolorallocate($im, 0, 0, 0);
imagefilledrectangle($im, 0, 0, $width, $height, $white);
foreach( $implode_coordinates as $key =>$coordinates_string ){
$coordinates[$key] = explode(‘;’, $coordinates_string);
$polygon_arrays_count[$key]=count($coordinates[$key])/2;
imagepolygon($im, $coordinates[$key], $polygon_arrays_count[$key] , $black);
}
ob_start();
imagepng($im);
$buffer = ob_get_clean();
//ob_end_clean();
$img = base64_encode($buffer);
imagedestroy($im);
return $img;
}

$image_array = array($implode_coordinates_db, $width, $height);
$image_base64 = image_create($image_array);
$image_src=’дані:image/png;base64,’.$image_base64;
echo “<img src='”.$image_src.”‘>”;